位置: IT常识 - 正文

使用 Vite 插件开发构建 Tampermonkey 用户脚本(vite 插件开发)

编辑:rootadmin
起因 一直以来,我都是直接在浏览器 Tampermonkey 扩展页面直接新建用户脚本来开发的: 对于一些简单的脚本,这没有什么问题,即改即看。但当代码多了以后问题就来了,自带编辑器开发体验确实不太舒服,没有格式化,没有代码补全,无法模块化编写代码等等,这时候我就想寻找一个打包方案,让我们可以在自己 ... 起因

推荐整理分享使用 Vite 插件开发构建 Tampermonkey 用户脚本(vite 插件开发),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vis插件,viz插件,vis插件,vite-plugin-legacy,vite 插件开发,vitagrafix插件怎么用,vu meter插件,vite 插件开发,内容如对您有帮助,希望把文章链接给更多的朋友!

一直以来,我都是直接在浏览器 Tampermonkey 扩展页面直接新建用户脚本来开发的:对于一些简单的脚本,这没有什么问题,即改即看。但当代码多了以后问题就来了,自带编辑器开发体验确实不太舒服,没有格式化,没有代码补全,无法模块化编写代码等等,这时候我就想寻找一个打包方案,让我们可以在自己的编辑器如 VSCode 里开发,这样就可以充分利用前端工程化的便利,提升开发体验。常见的打包工具比如 webpack、parcel、rollup 等,首先排除 webpack(笑),然后试了下 parcel,效果不太理想,之后试了 rollup 感觉还可以。转眼想到要用 vue 开发,那就直接上 vite 吧 ?,vite 也是用 rollup 来打包生产代码的。直接打开 npm,看看有没有人造轮子,然后发现下面几个包:

gorilla (rollup 插件)vite-plugin-tampermonkeyvite-plugin-monkey

这几个都符合基本需求,其中 gorilla 不能打包样式,另外两个插件都差不多,选了 vite-plugin-tampermonkey 进行改造。修改后的插件: Github | npm

插件特点通过单独的配置文件或者 package.json 中的 tmHeader 字段来配置 Tampermonkey 的 Userscript Header构建生产时支持自动分析代码用到的 grant开发模式时默认导入所有 grant,并且把所有的 grant 方法加入到 unsafeWindow可通过简单配置,把引入的外部包 require 化,自动引入 jsdelivr CDN ,详情见下面的插件配置开始之前

Vite 官方中文文档Tampermonkey 文档gorillavite-plugin-tampermonkeyvite-plugin-monkey

初始化项目使用 Vite 插件开发构建 Tampermonkey 用户脚本(vite 插件开发)

兼容性注意Vite 需要 Node.js 版本 >= 12.0.0。然而,有些模板需要依赖更高的 Node 版本才能正常运行,当你的包管理器发出警告时,请注意升级你的 Node 版本。

使用 NPM:

$ npm create vite@latest

使用 Yarn:

$ yarn create vite

使用 PNPM:

$ pnpm create vite

按需选择框架推荐使用 TypeScript然后到项目目录开始安装依赖

插件使用安装yarn add vite-plugin-tm-userscript -D# ORnpm install vite-plugin-tm-userscript -D配置 vite.config.tsimport { defineConfig } from 'vite'import Userscript from 'vite-plugin-tm-userscript'// https://vitejs.dev/config/export default defineConfig({ plugins: [ Userscript({ externalGlobals: ['vue'] }) ]})配置 Userscript Header

有四种方式来配置 Userscript Header, 优先级如下所示

header.config.jsonheader.config.jsheader.config.txtpackage.json 中的 tmHeader 字段

其中 header.config.txt 使用 Tampermonkey 头部注释配置,不会经过处理,直接插入脚本头部作为 Header 使用其他三种格式按 json 格式配置,多个属性配置如 match 用数组表示,经过处理自动添加 grant 与 require示例配置见 example/header.config.js使用 js 文件来配置的好处是可以有自动补全:具体属性配置见 Tampermonkey 文档

插件配置export interface TMPluginOptions { entry?: string; autoGrant?: boolean; externalGlobals?: string[] | Record<string, string | string[]>;}externalGlobals

配置外部包,比如 vue,axios 等,减少打包体积,并且会自动

本文链接地址:https://www.jiuchutong.com/zhishi/309313.html 转载请保留说明!

上一篇:Python中三种模块类型的介绍(python中模块的概念)

下一篇:当月销售次月开票怎么做账(当月销售次月开票就按次月申报)

  • 朋友圈自编地址怎么写(朋友圈自编地址文案)

    朋友圈自编地址怎么写(朋友圈自编地址文案)

  • 朋友圈一条直线中间一点什么意思(朋友圈一条直线一个点是什么意思)

    朋友圈一条直线中间一点什么意思(朋友圈一条直线一个点是什么意思)

  • 图片文字怎么转换成word(图片文字怎么转换成excel文档)

    图片文字怎么转换成word(图片文字怎么转换成excel文档)

  • 佳能6018硒鼓型号(佳能6018l硒鼓与哪个硒鼓兼容)

    佳能6018硒鼓型号(佳能6018l硒鼓与哪个硒鼓兼容)

  • 微信消息提示总显示艾特(微信消息提示总是延迟是什么原因)

    微信消息提示总显示艾特(微信消息提示总是延迟是什么原因)

  • 飞机上可以听蓝牙耳机么(飞机上可以听蓝牙音乐吗)

    飞机上可以听蓝牙耳机么(飞机上可以听蓝牙音乐吗)

  • 苹果内存可以扩大吗(苹果内存扩容是什么意思)

    苹果内存可以扩大吗(苹果内存扩容是什么意思)

  • 快手为什么看不到播放量(快手为什么看不到别人的动态)

    快手为什么看不到播放量(快手为什么看不到别人的动态)

  • 光猫lan灯闪烁无法上网

    光猫lan灯闪烁无法上网

  • 抖音限流是指所有视频吗(抖音限流是指所有人吗)

    抖音限流是指所有视频吗(抖音限流是指所有人吗)

  • 钉钉老师可以看到学生屏幕吗(钉钉老师可以看到学生在干什么吗)

    钉钉老师可以看到学生屏幕吗(钉钉老师可以看到学生在干什么吗)

  • 退货退款可以申请几次(退货退款可以申请两次吗)

    退货退款可以申请几次(退货退款可以申请两次吗)

  • 抖音主播可以设置几个管理员(抖音主播可以设置超管吗)

    抖音主播可以设置几个管理员(抖音主播可以设置超管吗)

  • 怎么删除word中的所有标记(怎么删除word中的回车符号)

    怎么删除word中的所有标记(怎么删除word中的回车符号)

  • 快手关注怎样超过1500(快手关注量已达到上限 怎么扩大关注量)

    快手关注怎样超过1500(快手关注量已达到上限 怎么扩大关注量)

  • airpods能以旧换新吗(air pods可以以旧换新)

    airpods能以旧换新吗(air pods可以以旧换新)

  • 抖音被限流了怎么办(抖音被限流了怎么办 解除)

    抖音被限流了怎么办(抖音被限流了怎么办 解除)

  • 手机流量封顶怎么解封(手机流量封顶怎么解封联通)

    手机流量封顶怎么解封(手机流量封顶怎么解封联通)

  • 小米cc9pro出厂带贴膜吗(小米cc9pro有什么新功能)

    小米cc9pro出厂带贴膜吗(小米cc9pro有什么新功能)

  • 苹果手机怎么下载视频(苹果手机怎么下载app并安装)

    苹果手机怎么下载视频(苹果手机怎么下载app并安装)

  • 华硕电脑密码忘了怎么办(华硕电脑密码忘记了怎么重置密码)

    华硕电脑密码忘了怎么办(华硕电脑密码忘记了怎么重置密码)

  • 抖音里的尬舞机去哪了(最新版抖音尬舞机在哪里打开)

    抖音里的尬舞机去哪了(最新版抖音尬舞机在哪里打开)

  • 地图定位怎么弄(企业地图定位怎么弄)

    地图定位怎么弄(企业地图定位怎么弄)

  • 抖音怎么保存静态壁纸(抖音怎么保存静态视频)

    抖音怎么保存静态壁纸(抖音怎么保存静态视频)

  • 小米8屏幕指纹版防水吗(小米8屏幕指纹版多少钱)

    小米8屏幕指纹版防水吗(小米8屏幕指纹版多少钱)

  • AI:ModelScope(一站式开源的模型即服务共享平台)的简介、安装、使用方法之详细攻略

    AI:ModelScope(一站式开源的模型即服务共享平台)的简介、安装、使用方法之详细攻略

  • 代扣代缴个人所得税有滞纳金吗
  • 现金股利和现金利润的区别
  • 小微企业注册流程及费用微
  • 银行日记账的登记实例图
  • 分公司能享受小微企业所得税优惠吗
  • 总分机构企业所得税汇算清缴
  • 利用个独企业避税犯法吗
  • 生产企业出口退税
  • 资产处置收益结转损益
  • 公司收到的其他发票
  • 认购私募股权基金
  • 销项发票采集不出来怎么回事
  • 企业增值税不可以跨月交吗
  • 地方水利建设基金的会计分录
  • 福利能开专票吗
  • 中药税率什么时候变为9
  • 合并报表的少数股东权益分录
  • 残保金征收单位
  • 税务师如何办理入会
  • 苹果手机上显示LTE是什么意思
  • w10系统程序停止运行
  • 本期填写的适用3减1政策的本期发生额大于
  • 使用最新版本的浏览器可以防御黑客
  • PHP:apache_request_headers()的用法_Apache函数
  • hp是什么代码
  • 债务重组利得计入投资收益还是营业外收入
  • g++.exe error
  • windows7如何制表
  • 劳务公司账务处理办法
  • 退货时可以按部分退货吗
  • node.js最新版本
  • 债务重组收益的计算
  • 计提本月固定资产折旧,其中车间折旧额1100
  • 购入电脑可以入成本里吗
  • 数据 挖掘
  • 微信手机充值怎么自定义金额
  • chcp命令
  • 普通发票冲红后还会有税吗
  • 初级会计直线法摊销
  • 企业投资计入什么科目
  • u8存货核算对方科目怎么设置
  • 金蝶专业版数量金额明细账设置
  • 水电费没有发票吗
  • 银行印鉴变更申请书范本
  • 预付工程款会计分录
  • 预付账款摊销会计分录
  • 低值易耗品入账
  • 无法确定退货率的处理
  • 捐赠出去的固定资产需要继续折旧吗
  • 办公家具可以一次性抵扣吗?
  • 错账查找方法主要有
  • 应付账款暂估可以法人付款吗
  • sql server高级应用
  • mysql优化的几种方法
  • Ubuntu Update-rc.d命令详细介绍
  • fedora 版本
  • windows升级10
  • centos设置ftp
  • win7系统安全软件
  • linux中sudoers
  • win8系统怎么打开运行
  • vb win7
  • win8安装wps
  • react native community
  • AndroidAnnotations 自定义控件 ant编译 找不到类
  • Node.js中的construct
  • .net 迭代器
  • 如何用nodejs搭建服务端
  • shc加密后不能运行
  • javascript高级程序设计电子书
  • 给shell脚本传参数
  • js移动端拖拽
  • jquery easyUI中ajax异步校验用户名
  • js的文件操作
  • android的控件有哪些
  • 机票票号怎么查航班
  • 公司地址变更后社保要改吗
  • 税务数据清理变态
  • 珠海南湾国际属于香洲哪个街道
  • 企业所得税优惠事项管理目录2023
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设