Visual Studio实现JS代码折叠功能

环境


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一下也许能事半功倍。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
一. 目的 在程序的开发中,javascript脚本的扩大,代码折叠,格式化是必不可少的一部分。对于大多数注释,代码折叠,格式化,都有着相似的样子,另外,在团队开发的过程,脚本太大,太长。为了提高在开发过程中,代码的可读性和开发效率,可以利用VS提供的Macro扩展功能实现一套Macro模板。在使用的过程中,只需要使用相应的快捷键,便可格式化脚本和查看代码结构。 二. 实现 1. 新建Macro工程 打开 菜单 --> Tools --> Macro --> New Macro Project...,根据向导提示建立工程。 2. 编辑Macro工程 打开 菜单 --> Tools --> Macro --> Macro Explorer ,在Explorer中选择新建的工程,修改Module名(右键),在Module名上双击,在打开的Macro IDE中进行编辑。 3. 在Module下,添加要实现的MacroForJs,并实现(内容为向Active Document中添加注释)。 4. 保存 5.在VS2008中,双击添加的Macro,将执行对应的Macro代码(使用VBScript在Macro IDE中实现的)。 6. 建立快捷键 打开 菜单 --> Tools --> Options --> Keyboard ,在列表框中选择刚才添加的MacroForJs里的OutlineFun (作用:注释),然后在 Press shortcuts keys中输入快捷键,点击Assign 。 打开 菜单 --> Tools --> Options --> Keyboard ,在列表框中选择刚才添加的MacroForJs里的FormatForJsChar (作用:格式化),然后在 Press shortcuts keys中输入快捷键,点击Assign 。 7. 这时候,就可以直接使用快捷键来执行MacroForJs 。 三. 使用附件 1. 加载 打开 菜单 --> Tools --> Macro --> Load Macro Project... ,选择附件里的工程。 2. 配置快捷键 3. 完成 具体的实现代码见附件工程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值