上一主题 下一主题
ScriptCat,新一代的脚本管理器脚本站,与全世界分享你的用户脚本油猴脚本开发指南教程目录
返回列表 发新帖

一个vscode可以批量注释xml的插件

[复制链接]
  • TA的每日心情
    开心
    2024-7-16 15:40
  • 签到天数: 276 天

    [LV.8]以坛为家I

    115

    主题

    460

    回帖

    997

    积分

    荣誉开发者

    积分
    997

    荣誉开发者油中2周年卓越贡献生态建设者油中3周年

    发表于 2022-7-9 12:10:24 | 显示全部楼层 | 阅读模式

    https://dllm.lanzouv.com/b017redkd
    密码:i99l

    因为xml不支持嵌套注释,但是我又找不到如何批量单行注释的快捷键和方法,所以写了一下。
    时间都浪费在看不懂英文的api文档上了。
    分享一下。代码都在蓝奏云自学下载就好了。
    有前端基础的,我把package.json文件和extension.js文件贴出来就看懂了。因为我只懂了这两个文件。

    参考的文档也给来一个:https://juejin.cn/post/7010765441144455199

    {
      "name": "batchAnnotationXml-plugin-wuming",
        "displayName": "batchAnnotationXml-plugin-wuming",
        "description": "可以给xml进行批量单行注释",
        "version": "0.0.1",
      "icon": "images/zhushi.png",
      "publisher": "xiaokedou",
        "engines": {
            "vscode": "^1.66.0"
        },
        "categories": [
            "Other"
        ],
        "activationEvents": [
            "onCommand:batchAnnotationXml-plugin-wuming.batchAnnotationXml",
            "onCommand:extension.demo.getCurrentFilePath"
        ],
        "main": "./extension.js",
        "contributes": {
            "commands": [
          {
                "command": "batchAnnotationXml-plugin-wuming.batchAnnotationXml",
                "title": "批量注释"
          },
          {
            "command": "extension.demo.getCurrentFilePath",
            "title": "获取当前文件路径"
          }
        ],
        "menus": {
          "editor/context": [
                    {
                        "when": "editorFocus",
                        "command": "extension.demo.getCurrentFilePath",
                        "group": "navigation"
                    },
            {
              "when": "editorFocus",
              "command": "batchAnnotationXml-plugin-wuming.batchAnnotationXml",
              "group": "navigation"
                    }
                ],
                "explorer/context": [
                    {
                        "command": "extension.demo.getCurrentFilePath",
                        "group": "navigation"
                    }
                ]
        }
        },
        "scripts": {
            "lint": "eslint .",
            "pretest": "npm run lint",
            "test": "node ./test/runTest.js"
        },
        "devDependencies": {
            "@types/vscode": "^1.66.0",
            "@types/glob": "^7.2.0",
            "@types/mocha": "^9.1.0",
            "@types/node": "14.x",
            "eslint": "^8.11.0",
            "glob": "^7.2.0",
            "mocha": "^9.2.2",
            "typescript": "^4.5.5",
            "@vscode/test-electron": "^2.1.3"
        }
    
    }
    
    const vscode = require('vscode');
    
    /**
     * @param {vscode.ExtensionContext} context
     */
    function activate(context) {
        console.log('vscode插件已经激活');
    
        let disposable = vscode.commands.registerCommand('batchAnnotationXml-plugin-wuming.batchAnnotationXml', function () {
        // const path = '/Users/d/Desktop/testreact2/react练习项目/xml的学习/按压效果.html';
        // const options = {
        //   // 选中第3行第9列到第3行第17列
        //   selection: new vscode.Range(new vscode.Position(2, 8), new vscode.Position(2, 16)),
        //   // 是否预览,默认true,预览的意思是下次再打开文件是否会替换当前文件, 假如为false就是你关闭以后再次打开的时候它还是会选中指定内容
        //   preview: false,
        //   // 显示在第二个编辑器
        //   viewColumn: vscode.ViewColumn.Two
        // };
        // vscode.window.showTextDocument(vscode.Uri.file(path), options);
        const { document, selection } = vscode.window.activeTextEditor;
        document.uri; // 获取编辑文件 Uri
        document.getText(); // 获取编辑器文本内容
        document.getText(selection); // 获取选中部分内容
        // 文件总行数
        let lineCount = document.lineCount;
        if(selection.isEmpty){
          vscode.window.showWarningMessage("请选择要单行注释的内容,这个软件只对xml文件的注释有效")
        } else {
          // 拿到选中的开始的行号
          let startLine = selection.start.line;
          // 拿到选中的结束的行号
          let endLine = selection.end.line;
          // 选中文本一行的开始的位置
          let start_num = selection.start.character;
          // 选择文本一行的结束的位置
          var end_num = selection.end.character;
          let selectContent =document.getText(selection).split(/[(\r\n)\r\n]+/);
          // 这里遍历两次是因为我删除数组里面一个空格的位置,数组的长度发送了变化,后面的补到原来空格占的索引的位置,导致我遍历补到所以我就为了
          // 方便写了遍历两次
          selectContent.forEach((item,index)=>{
            // console.log(item,index);
            // trim方法去除首尾的空格
            if(!item.trim()){
              // 表示在索引的位置删除一个元素,就是把空格的删除了
              selectContent.splice(index,1);
            } 
          })
          selectContent.forEach((item,index)=>{ 
            if(item.indexOf('<!--') > -1){
              console.log(item);
              console.log('注释的代码');
            }else{
              selectContent[index] = '<!-- ' + item + ' -->'
            }
          })
    
          console.log(selectContent);
    
          vscode.window.activeTextEditor.edit(editBuilder => {
            // // 从开始到结束,全量替换
            // const end = new vscode.Position(vscode.window.activeTextEditor.document.lineCount + 1, 0);
            // const text = '新替换的内容';
            // // (0,0)表示的就是最开始的坐标
            // editBuilder.replace(new vscode.Range(new vscode.Position(0, 0), end), text);
            //  新增代码
            // let lines_add = [];
            // lines_add.push(document.lineAt(lineCount - 1).text);
            // lines_add.push('你好世界');   
            let range = new vscode.Range(
              startLine,
              start_num,
              endLine,
              end_num
            )
            editBuilder.replace(range, selectContent.join('\n'))
        });
    
        }
    
        // vscode.workspace.fs.writeFile(document.uri, new Uint8Array(Buffer.from(document.getText()))); 
            vscode.window.showInformationMessage('欢迎使用插件,这个插件是给xml进行批量注释的');
        });
    
        context.subscriptions.push(disposable);
      // 获取文件的路径
      context.subscriptions.push(vscode.commands.registerCommand('extension.demo.getCurrentFilePath', (uri) => {
        vscode.window.showInformationMessage(`当前文件(夹)路径是:${uri ? uri.path : '空'}`);
      }));
    
    }
    
    function deactivate() {
      console.log("插件已经关闭");
    }
    
    module.exports = {
        activate,
        deactivate
    }
    

    image.png

    image.png

    接脚本定制
    I frequently record, because want to leave something.
  • TA的每日心情
    开心
    2024-7-16 15:40
  • 签到天数: 276 天

    [LV.8]以坛为家I

    115

    主题

    460

    回帖

    997

    积分

    荣誉开发者

    积分
    997

    荣誉开发者油中2周年卓越贡献生态建设者油中3周年

    发表于 2022-7-9 12:16:40 | 显示全部楼层
    写完以后一百度 ,https://blog.csdn.net/qq_33423991/article/details/100985765   绝了,昨天一天没百度到
    接脚本定制
    I frequently record, because want to leave something.
    回复

    使用道具 举报

  • TA的每日心情
    开心
    昨天 13:37
  • 签到天数: 213 天

    [LV.7]常住居民III

    305

    主题

    4189

    回帖

    4056

    积分

    管理员

    积分
    4056

    管理员荣誉开发者油中2周年生态建设者喜迎中秋油中3周年挑战者 lv2

    发表于 2022-7-9 16:54:34 | 显示全部楼层
    写点小插件还是挺有意思的
    上不慕古,下不肖俗。为疏为懒,不敢为狂。为拙为愚,不敢为恶。
    回复

    使用道具 举报

    发表回复

    本版积分规则

    快速回复 返回顶部 返回列表