让Visual Studio 也支持JS代码折叠 [ Visual Studio | #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.  编辑宏:  

Option Strict Off


Option Explicit Off






Imports System


Imports EnvDTE


Imports EnvDTE80


Imports System.Diagnostics


Imports System.Collections






Public Module JsMacros






    Sub OutlineRegions()


        Dim selection As EnvDTE.TextSelection = DTE.ActiveDocument.Selection






        Const REGION_START As String = "//#region"


        Const REGION_END As String = "//#endregion"






        selection.SelectAll()


        '农民伯伯 --- 自动为"//#endregion"结束的代码添加最后一行,不然出错


        If selection.Text.EndsWith(REGION_END) Then


            selection.EndOfLine()


            selection.NewLine()


            selection.SelectAll()


        End If










        Dim text As String = selection.Text


        selection.StartOfDocument(True)






        Dim startIndex As Integer


        Dim endIndex As Integer


        Dim lastIndex As Integer = 0


        Dim startRegions As Stack = New Stack()






        Do


            startIndex = text.IndexOf(REGION_START, lastIndex)


            endIndex = text.IndexOf(REGION_END, lastIndex)






            If startIndex = -1 AndAlso endIndex = -1 Then


                Exit Do


            End If






            If startIndex <> -1 AndAlso startIndex < endIndex Then


                startRegions.Push(startIndex)


                lastIndex = startIndex + 1


            Else


                ' Outline region 


                selection.MoveToLineAndOffset(CalcLineNumber(text, CInt(startRegions.Pop())), 1)


                selection.MoveToLineAndOffset(CalcLineNumber(text, endIndex) + 1, 1, True)


                selection.OutlineSection()






                lastIndex = endIndex + 1


            End If


        Loop






        selection.StartOfDocument()


    End Sub






    Private Function CalcLineNumber(ByVal text As String, ByVal index As Integer)


        Dim lineNumber As Integer = 1


        Dim i As Integer = 0






        While i < index


            If text.Chars(i) = vbCr Then


                lineNumber += 1


                i += 1


            End If






            i += 1


        End While






        Return lineNumber


    End Function






End Module

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

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

 

  4.  设置快捷键

   

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

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

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

 

  5.效果

    5.1  输入代码:


// aasdsadsad

// #region
//
#endregion

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

     

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

      

 

结束

  想到不如做到,但做之前要是能先Google一下也许能事半功倍: )

转载自: http://www.cnblogs.com/over140/archive/2009/06/15/1503712.html

一切因版权所产生的法律责任本帖概不负责

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
'******vs实现js格式化和代码折叠****** '* 版权所有(C) sksmks 2009 '* 文件名称 : JsFormat '* 当前版本 : 1.0.0.1 '* 作 者 : 黄会攀 (@@:272302281) '* 设计日期 : 2009年10月31日 '* 内容摘要 : VS2008 JsFormat Macro '*******************************************************************************/ 一. 目的 在程序的开发中,javascript脚本的扩大,代码折叠,格式化是必不可少的一部分。对于大多数注释,代码折叠,格式化,都有着相似的样子,另外,在团队开发的过程,脚本太大,太长。为了提高在开发过程中,代码的可读性和开发效率,可以利用VS提供的Macro扩展功能,实现一套Macro模板。在使用的过程中,只需要使用相应的快捷键,便可格式化脚本和查看代码结构。 二. 实现 (打开宏资源管理器:视图 -> 其他窗口 -> 宏资源管理器 或者按 Alt+F8) 1. 新建Macro工程 打开 菜单 --> 工具 --> 宏(Macro) --> 新建宏(New Macro Project...),或者(宏资源管理器Alt+F8 )根据向导提示建立工程。 2. 编辑Macro工程 打开 菜单 --> 工具 --> 宏(Macro) --> 宏资源管理器(Macro Explorer) ,在Explorer中选择新建的工程,修改Module名(右键),在Module名上双击,在打开的Macro IDE中进行编辑。 3. 在Module下,添加要实现的MacroForJs,并实现(内容为向Active Document中添加注释)。 4. 保存 5.在VS2008中,双击添加的Macro,将执行对应的Macro代码(使用VBScript在Macro IDE中实现的)。 6. 建立快捷键 打开 菜单 --> 工具 --> 选项 --> 键盘 ,在列表框中选择刚才添加的MacroForJsPro里的OutlineFun (作用:注释),然后在 Press shortcuts keys中输入快捷键,点击Assign 。 打开 菜单 --> 工具 --> 选项 --> 键盘 ,在列表框中选择刚才添加的MacroForJsPro里的FormatForJsChar (作用:格式化),然后在 Press shortcuts keys中输入快捷键,点击Assign 。 7. 这时候,就可以直接使用快捷键来执行MacroForJs 。 三. 使用附件 1. 加载 打开 菜单 --> 工具(Tools) --> 宏(Macro) --> 加载宏项目(Load Macro Project... ),选择附件里的工程。 2. 配置快捷键 3. 完成 具体的实现代码见附件工程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值