简体中文| English
使用Node.js
+Webpack
模块化开发油猴脚本的方案,用于提升油猴开发体验,降低开发时的心智负担,让油猴脚本也能当做一个普通的模块化的前端项目来开发,要不然一个JavaScript
文件几千行来回改本人真的有点顶不住......
- 模块化开发油猴项目,开发体验与效率都能够得到大幅提升,再也不需要头疼怎么在单个
JavaScript
文件中组织代码了(油猴商店上架的脚本得是单文件无混淆无压缩,模块化开发打包出来的JS也是符合上架要求的) - 开发时热加载提高开发效率,采用推荐的开发模式,油猴中指向打包结果本地文件地址,
JavaScript
代码有变化时自动编译打包加载,开发时修改代码测试更高效(写过油猴脚本的应该都有过这种糟糕的体验,来来回回修改代码测试非常花费时间简直要了老命) - 发布时打包后的为高可读性的单
JavaScript
文件,符合油猴商店的上架政策,打包出来就能上架不再需要什么手工处理的工作,简单方便不麻烦
在当前仓库(https://github.com/JSREI/userscript-template)选择“`Use this template” --> “
Create a new repository`”,从这个模板仓库创建一个新的仓库:
选择新仓库存放的位置以及设置仓库名字等等,通常把新仓库挂在自己的账号下边即可:
新仓库创建好了克隆到本地,然后在克隆到的项目根目录下执行命令安装项目所需依赖:
npm install
安装依赖可能会花点时间,稍微耐心等待一会儿:
如果依赖安装过慢或者下载不下来,可以为npm
配置国内镜像源或者使用cnpm
(自行谷歌)。
然后修改package.json
文件,把相关字段替换为你自己的,比如名字、作者、仓库地址等等:
{
"name": "userscript-foo",
"version": "0.0.1",
"main": "index.js",
"repository": "https://github.com/JSREI/userscript-template.git",
"scripts": {
// ...
},
"author": "CC11001100 <[email protected]>",
"license": "MIT",
"devDependencies": {
//...
}
}
在项目根目录下的userscript-headers.js
文件中存放的是默认的油猴头文件,在webpack
编译的时候会把这个文件放到编译后的文件的头部作为油猴的插件声明:
// ==UserScript==
// @name ${name}
// @namespace ${repository}
// @version ${version}
// @description ${description}
// @document ${document}
// @author ${author}
// @match *://*/*
// @run-at document-start
// ==/UserScript==
${name}
、${version}
这种是本油猴脚手架支持的一些变量,原理就是在编译的时候会从package.json
中获取对应的值把变量替换掉(这就是所谓的变量渲染),这样对于这些可能会重复或者一直变的内容我们就可以从一个源引用使用而不用重复设置或者反复修改了,如果默认的配置不能满足你的要求,你可以直接修改这个头文件,比如为其增加权限:
// ==UserScript==
// @name ${name}
// @namespace ${repository}
// @version ${version}
// @description ${description}
// @document ${document}
// @author ${author}
// @match *://*/*
// @run-at document-start
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_registerMenuCommand
// @grant GM.getValue
// @grant GM.setValuex
// @grant GM.registerMenuCommand
// ==/UserScript==
除了变量替换其他内容都会被原样保留,这是编译后的样子:
然后就可以开心的写代码了,在编写代码的时候你可以使用npm
命令为项目添加依赖,对于一个稍微复杂点的脚本而言很可能会引用外部的依赖:
npm add xxx
但是需要注意,这些依赖最终会被打包进./dist/index.js
,而这个文件是不适合太大的,所以尽可能不要引用太多的第三方库。
同时你现在可以在src
目录下以模块化的方式组织你的代码,而不必像之前那样来回上下拉扯一个几千行的JavaScript
文件(单文件开发那简直是一种对脑力的摧残...):
当你需要测试的时候,执行:
npm run watch
然后把./dist/index.js
中的文件头复制到你的油猴中:
并在最后添加一行引入编译后的文件,注意这个file://
后面的地址是指向你的编译后的./dist/index.js
的绝对路径:
// @require file://D:/workspace/userscript-template/dist/index.js
比如下面是一个开发时使用的油猴脚本的实际例子,油猴中没有实际代码,而是使用require
指向我们build
后的文件,这样当修改完代码webpack
自动热编译的时候浏览器中引用的./dist/index.js
也是最新的:
// ==UserScript==
// @name userscript-foo
// @namespace https://github.com/JSREI/userscript-template.git
// @version 0.0.1
// @description
// @document
// @author CC11001100 <[email protected]>
// @match *://*/*
// @run-at document-start
// @require file://D:/workspace/userscript-template/dist/index.js
// ==/UserScript==
(() => {})();
注意,当你使用// @require file://D:/workspace/userscript-template/dist/index.js
这种方式来调试的时候,你的油猴插件应该配置了允许访问文件网址(默认情况下是不允许的),在浏览器插件图标上右键,选择”管理扩展程序“:
确保这个”允许访问文件网址“开关是打开的,否则的话@require
将无法引用本地文件:
也许你会注意到,当你使用npm run watch
运行的时候,命令执行时编译完代码了也并没有退出而是进入了等待状态,是的,就像它的名字一样,它是启动了一个watch
模式,当你改动源代码文件的时候webpack
都会帮你重新编译你的代码,而你需要做的就是直接修改你的源代码文件,修改完然后切换到浏览器刷新页面即可生效!(这里没有引入浏览器自动刷新,是否有这个必要呢?说实话有必要我也不大会弄凑活着用吧....)
当你需要发布的时候:
npm run build
然后把./dist/index.js
文件拿去发布即可。