How do you hide arbitrary section of code in VS Code?

28,872

Solution 1

You can use the following delimiters for code folding:

C/C++:       #pragma region and #pragma endregion
C#:          #region and #endregion
CSS:         /* #region */ and /* #endregion */
Java:        //region and //endregion
JavaScript:  //#region and //#endregion and //region and //endregion
PHP:         #region and #endregion
Powershell:  #region and #endregion
Python:      #region and #endregion
VB:          #Region and #End Region

See https://github.com/Microsoft/vscode/issues/12146 ([folding] fold regions)

Solution 2

Unfortunately, it doesn't appear that VSCode currently allows you to hide an arbitrary selection of code like Visual Studio does via Ctrl+M,Ctrl+H. For now you could use the code folding feature, which depends on indentation. That is, if you indent the code you want to hide, you could then collapse it via Ctrl+Shift+[, like so:

code folding in vscode

Obviously, this is kind of an ugly solution to your problem; it requires multiple steps and makes actual changes to the file. Also, it's clearly useless if you're writing in a whitespace-dependent language like Python, but I don't think you are going to find a better solution short of finding an extension (or writing one yourself). It also might be worth posting an issue on the official VSCode GitHub repo if this feature is important to you.

Share:
28,872

Related videos on Youtube

Sajuuk
Author by

Sajuuk

mostly programming and security stuff

Updated on July 09, 2022

Comments

  • Sajuuk
    Sajuuk almost 2 years

    By "VS Code" I mean the lightweight text editor not the monolithic IDE, unfortunately searching this on google will bring up many pieces of irrelevant information about how to do this in Visual Studio.

    To the question itself, Anybody knows how to hide arbitrary selected lines of code in "Visual Studio Code", preferably into a plus sign like collapsing does?

    Note: this is different than collapsing nested code which probably could be achieved by Ctrl+K,Ctrl+<num> , what I need here is to hide specific block of code of choice, no matter nested or not.

    EDIT: I see there are people who don't understand my requirements.

    for example, you may think what I want is this:

    before hiding:

    for i in j:
        for k in i:
            for l in k:
                somestuff...
    

    after hiding:

    [+] for i in j: ...
    

    What I actually want is this:

    before hiding:

    # doing stuff about a
    a = ClassA()
    a.bar()
    a.i = 2
    a.j = 3
    a.k = 5
    

    after hiding:

    [+] ...  ( doing stuff about a )
    

    2017.10.17 EDIT: turns out VS Code implemented a very similar feature called "Folding Regions" in VS Code 1.17.1 Update. link

  • Sajuuk
    Sajuuk over 5 years
    In retrospection your answer was creative and almost correct at that moment, sorry that I didn't choose you because this might not work in some indent sensitive languages.
  • Nacimota
    Nacimota over 5 years
    @Sajuuk no worries, I conceded that as part of the answer. Ideally it should be something vscode does by itself.
  • Dave Ceddia
    Dave Ceddia over 2 years
    Dissecting some C code right now, and trying to hide chunks of code beyond just folding it. The indentation trick didn't work for some reason, but I added #if 1 and #endif around the blocks I wanted to hide and that got it done :) Thanks for the idea!
  • Albert Renshaw
    Albert Renshaw about 2 years
    I wish it would stay folded across sessions. Don't like having secret keys visible on my monitor :\