`

让Visual Studio 也支持JS代码折叠 [ #region | #endregion ]

 
阅读更多

前言

Visual Studio的代码折叠功能非常好用,#region #endregion 这个词连搜狗的词库里面都出现了(不含'#'号),可见使用频率很高,但是他不支持js的代码折叠 : ( 最近Ext用得比较多,一写就是上百行JS代码,非常不方便,想着自己写个扩展或插件什么的,意外搜到了下面的文章,已经用宏来实现了,本文可以理解为该文的简单译本,注意宏代码部分我有所改动 : )

文章

1.Using #region Directive With JavaScript Files in Visual Studio

环境

Microsoft Visual Studio 2008

正文

1. 打开宏资源管理器:视图 ->其他窗口->宏资源管理器

  

2. 创建一个新模块

  

  3.  编辑宏:  选中模块 -> 右键编辑

<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->OptionStrictOff
OptionExplicitOff

ImportsSystem
ImportsEnvDTE
ImportsEnvDTE80
ImportsSystem.Diagnostics
ImportsSystem.Collections

PublicModuleJsMacros

SubOutlineRegions()
DimselectionAsEnvDTE.TextSelection=DTE.ActiveDocument.Selection

ConstREGION_STARTAsString="//#region"
ConstREGION_ENDAsString="//#endregion"

selection.SelectAll()
'农民伯伯---自动为"//#endregion"结束的代码添加最后一行,不然出错
Ifselection.Text.EndsWith(REGION_END)Then
selection.EndOfLine()
selection.NewLine()
selection.SelectAll()
EndIf


DimtextAsString=selection.Text
selection.StartOfDocument(
True)

DimstartIndexAsInteger
DimendIndexAsInteger
DimlastIndexAsInteger=0
DimstartRegionsAsStack=NewStack()

Do
startIndex
=text.IndexOf(REGION_START,lastIndex)
endIndex
=text.IndexOf(REGION_END,lastIndex)

IfstartIndex=-1AndAlsoendIndex=-1Then
ExitDo
EndIf

IfstartIndex<>-1AndAlsostartIndex<endIndexThen
startRegions.Push(startIndex)
lastIndex
=startIndex+1
Else
'Outlineregion
selection.MoveToLineAndOffset(CalcLineNumber(text,CInt(startRegions.Pop())),1)
selection.MoveToLineAndOffset(CalcLineNumber(text,endIndex)
+1,1,True)
selection.OutlineSection()

lastIndex
=endIndex+1
EndIf
Loop

selection.StartOfDocument()
EndSub

PrivateFunctionCalcLineNumber(ByValtextAsString,ByValindexAsInteger)
DimlineNumberAsInteger=1
DimiAsInteger=0

Whilei<index
Iftext.Chars(i)=vbCrThen
lineNumber
+=1
i
+=1
EndIf

i
+=1
EndWhile

ReturnlineNumber
EndFunction

EndModule

    保存即可。这里可以省去新建宏的步骤,他会根据代码自动给你生成一个宏的。

    注意我加的代码段,如果不加,并且你的JS最后一行为#endregion,宏将报错,显示“值不在预期的范围内”。

  4.  设置快捷键

  

    4.1  工具 -> 选项 - > 环境 -> 键盘

    4.2  在显示命令包含下面的文本框中输入宏名outli,不用输全,下面能显示你新建的宏

    4.3  点一下 按快捷键 下面的文本框, 然后自定义快捷键组合,我定义的是Ctrl+M,Ctrl+J,点分配(别忘了!),点确定。

  5.效果

    5.1  输入代码:

<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
//aasdsadsad

//#region
//
#endregion

    5.2  快捷键Ctrl+M,Ctrl+J启动宏,能看到系统的右下角显示可爱的小方块在转动,js编辑框显示效果如下:

    

    5.3  之后就可以用快捷键Ctrl+M,Ctrl+L来[展开/折叠]代码了,注意关闭之后重新打开需要再启动一次宏,展开效果如下:

    

结束

分享到:
评论

相关推荐

    代码折叠插件_com.cb.eclipse.folding_1.0.6.rar

    用过 Visual Studio 的朋友都知道 #region ... #endregion 可以将一段代码包围起来使其成为在 IDE 中可以被折叠或展开的代码块,这一功能可以提高代码的可读性。  但 eclipse 并没有类似的功能。在 eclipse 中能够...

    eclipse Java代码折叠插件_ Code Folding

    类似于 Visual Studio 中的 #region #endregion 可以将一段代码包围起来使其成为在 IDE 中可以被折叠或展开的代码块,提高代码的可读性。

    com.cb.eclipse.folding_1.0.6.jar

    Eclipse实现Visual Studio 中的 #region .#endregion 折叠代码块的功能

    代码块折叠 com.cb.eclipse.folding

    类似于 Visual Studio 中的 #region .#endregion 可以将一段代码包围起来使其成为在 IDE 中可以被折叠或展开的代码块,提高代码的可读性。

    com.cb.eclipse.folding.KAM-3.5.zip Eclipse代码折叠插件

    用过 Visual Studio 的朋友都知道 #region #endregion 可以将一段代码包围起来使其成为在 IDE 中可以被折叠或展开的代码块 这一功能可以提高代码的可读性 此插件可让eclipse支持类似功能 使用方式: 1 download ...

    Wikitext-VSCode-Extension:一个Visual Studio代码扩展,为Wikitext提供语言支持

    此Visual Studio代码扩展提供了对Wikitext标记语言的支持。 通过此扩展,您可以通过标记和样式化的文本更轻松地发现语法问题。 该插件基于MediaWiki的Wikitext标准,但是规则有些严格,可以帮助用户编写易于阅读和...

    用Visual C# 2005开发的文本编辑器(修正版)

    &lt;br/&gt;程序里我用#region与#endregion把form1.cs里的代码都分类了,如在Visual Studio 2005环境内可以选择性的展开查看代码。 &lt;br/&gt;状态栏中间的信息是显示这个文件中所含的手动回车换行符的个数+1 (也就是...

    vscode-LaTeX-support:对Visual Studio Code的LaTeX语言支持

    LaTeX语言对Visual Studio Code的支持 此扩展添加了LaTeX语言的语法突出显示和摘要。 我基于和。 产品特点 BibTeX , LaTeX和TeX语言的语法突出显示。 折叠区域具有定义的标记: %Region和%Endregion 。 片段。 ...

    用Visual C# 2005开发的文本编辑器

    &lt;br/&gt;程序里我用#region与#endregion把form1.cs里的代码都分类了,如在Visual Studio 2005环境内可以选择性的展开查看代码。 &lt;br/&gt;状态栏中间的信息是显示这个文件中所含的手动回车换行符的个数+1 (也就是...

    C#经验技巧宝典1-5

    0027 #region、#endregion关键字的使用技巧 14 0028 “///”符号的使用技巧 14 0029 使用注释取消程序语句的执行 15 2.2 语句 15 0030 跳转语句GOTO的使用 15 0031 Continue语句的使用 16 0032 ...

    Vs2008快捷键和技巧文本

    Visual Studio 2008提高工作效率的小技巧 时间往往在不经意间就浪费掉了,比如我们在寻找上一个光标位置的时候,好好学习并利用下面的技巧,会提高工作效率,减少不必要浪费的时间,提高时间利用率,让生活更加美好...

    .NET中实现客户端联动菜单 (无刷新)

    &lt;meta content="Microsoft Visual Studio .NET 7.1" name="GENERATOR"&gt; &lt;meta content="JavaScript" name="vs_defaultClientScript"&gt; &lt;SCRIPT language="javascript"&gt; //城市-----------------------------...

    visual assist 1707破解

    * VA Outline correctly displays C++ #pragma region/endregion nodes. (case=20612) 8274 * Multiline XML comments no longer contain extraneous '/' characters in VA Outline. (case=18539) 8005 * ...

    visual assist 10.5.1707

    VA Outline correctly displays C++ #pragma region/endregion nodes. (case=20612) 8274 Multiline XML comments no longer contain extraneous '/' characters in VA Outline. (case=18539) 8005 Document ...

    网页页面图片批量下载

    Microsoft Visual Studio 2005 二. 部分代码说明(主要讲解异步分析和下载): 异步分析下载采取的策略是同时分析同时下载,即未等待数据全部分析完毕就开始把已经分析出来的图片链接开始下载。下载成功的均在...

Global site tag (gtag.js) - Google Analytics