JavaScript: Code Folding

Posted by Petr on Oracle Blogs See other posts from Oracle Blogs or by Petr
Published on Sun, 1 Apr 2012 19:40:00 -0500 Indexed on 2012/04/02 11:36 UTC
Read the original article Hit count: 354

Filed under:

Today I would like to mentioned code folding in the new JavaScript editor support, which is available in the continual builds from our server. It's a basic feature, but was mentioned in a comment under the mentioned post.

So you can fold comments and every code block between { and }. The current support allows only methods to be folded. The difference is shown below. In the picture on the left side is the current folding and on the right side the new one.  

The code folding can be switched off in the Editor Options (Tools main menu -> Options -> Editor category -> General Tab). In this dialog you can also define which folds should be collapsed by default when you open a file. These options more closely fit Java editor needs, but you can see in the next picture how the options are mapped for JavaScript code.

 The Method option folds all functions in the code. Other code blogs are fold through the option Tags and Other Code Blogs.  The documentation comments (starts with /**) are fold through Javadoc Comments and when you check Initial Comment, then all comments that start with /* are folded by default. 

The new JavaScript editor also supports custom folds. To add your custom fold, type in two special comments as shown in this example:

   // <editor-fold>
   Your code goes here...
   // </editor-fold>
You can define the default description of a collapsed fold by adding a "desc" attribute:
   
   // <editor-fold desc="This is my super secret genius code.">
   Your code goes here...
   // </editor-fold>
You can set a fold to be collapsed by default by adding a "defaultstate" attribute:
   
   // <editor-fold defaultstate="collapsed">
   Your code goes here...
   // </editor-fold>

There is a code template that helps with writing custom fold comments. The abbreviation for the template is fcom.

As I wrote the new JS support is available in the continual builds. Go here for more info.

© Oracle Blogs or respective owner

Related posts about /Features