位置: 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中模块的概念)

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

  • 固定资产更新改造资本化条件
  • 本年利润和利润分配未分配利润的区别
  • 处置废品收入需要开票吗东奥
  • 土地增值税预缴税率
  • 当月没有发生购销合同还要报印花税吗
  • 合同解除收取对方的违约金交什么税
  • 劳务公司发放农民工工资的三种形式
  • 佣金收入者是什么意思
  • 认缴制下收到股东转入的钱怎么入账
  • 租客一次性支付一年租金需要交个税吗
  • 企业合并以外
  • 印花税这个月没交怎么办
  • 电商公司怎么开发票
  • 社保不报的情况下保险报销吗
  • 股利分配政策的研究背景
  • 资产处置损益的明细科目有哪些
  • 劳务费个人还需要交税吗
  • 小规模计提税金及附加怎么算
  • 折价购买债券是什么意思
  • 资产和负债可以一增一减吗
  • 未计提工资
  • 不动产进项税额怎么算
  • 出差人什么意思
  • 调整增值税税率
  • 普通年金的概念和内涵
  • 公司固定资产出售给个人
  • 行政事业单位临聘人员
  • 个人向公司借款模板
  • 已认证进项税发票可抵扣么
  • 应收票据包括哪些支票
  • pniopcac.exe是什么
  • php 操作mysql
  • 以前年度损益调整属于哪类科目
  • 收外汇怎么做账报税
  • php表单提交输入判断
  • php对数组进行排序
  • 成本价低于现价 应该卖吗
  • CUDA版本选择
  • js javascript
  • 机器学习分类算法之XGBoost(集成学习算法)
  • linux 静态链接
  • 年末结转利润分配各明细账户
  • 文化事业建设费的征收范围
  • 发票开错时,如何做账务处理?
  • 购销农副产品需要交税吗
  • 小规模纳税人的企业所得税怎么算
  • 采购材料单表格
  • 会员退费怎么算
  • 个人独资企业怎么交个人所得税
  • 购买预付卡如何开发票
  • 什么单位需要
  • 应收帐款的帐务处理流程
  • 餐费开增值税专用发票
  • 已抵扣未申报的税额如何转出
  • 收到的发票怎么做分录
  • 给客户购物卡如何充钱
  • 建账的大体流程是什么
  • freebsd 升级
  • mac怎么设置默认打开方式
  • 重装系统要注意哪些
  • WIN XP下VMware Tools(虚拟机)安装的详细方法(图文教程)
  • ptssvc.exe - ptssvc是什么进程 有什么用
  • win7注册表详解
  • 如何使用u盘安装linux
  • win10系统开机重装教程
  • unity特效制作教程
  • js call.call
  • shutil模块 python安装
  • 深入解析抑郁症:什么是它的表现?别小看它的危害程度!
  • javascript初学者书籍
  • Python快速从注释生成文档的方法
  • 如何在脚本中调字体
  • jquery技巧
  • 如何查询自己公司的对公账号
  • 国家税务总局惠州仲恺高新技术产业开发区税务局
  • 北京市国家税务局发票查询
  • 印花税应税凭证数量是什么意思
  • 18款凯美瑞中控屏
  • 个体工商户怎样交税
  • 2023个税税率及速算扣除数
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设