位置: IT常识 - 正文

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

发布时间:2024-01-25
起因 一直以来,我都是直接在浏览器 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中模块的概念)

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

  • 支付宝社保卡怎么更换参保地(支付宝社保卡怎么查余额)

    支付宝社保卡怎么更换参保地(支付宝社保卡怎么查余额)

  • 天猫精灵智能音响怎么连接(天猫精灵智能音响怎么连接网络)

    天猫精灵智能音响怎么连接(天猫精灵智能音响怎么连接网络)

  • 手机图案解锁忘了怎么办(手机图案解锁忘记密码怎么解决oppoa57)

    手机图案解锁忘了怎么办(手机图案解锁忘记密码怎么解决oppoa57)

  • ios13可以清空流量统计吗(ios清空流量数据)

    ios13可以清空流量统计吗(ios清空流量数据)

  • 微信看一看视频怎么下载(微信看一看视频播放不了)

    微信看一看视频怎么下载(微信看一看视频播放不了)

  • 抖音上共同联系人要达到什么条件下能看见(抖音共同联系人和共同朋友的区别)

    抖音上共同联系人要达到什么条件下能看见(抖音共同联系人和共同朋友的区别)

  • 秘乐短视频是什么东西(秘乐短视频什么时候关闭)

    秘乐短视频是什么东西(秘乐短视频什么时候关闭)

  • 华为p40nfc在哪里打开(华为p40nfc在哪里关闭)

    华为p40nfc在哪里打开(华为p40nfc在哪里关闭)

  • 钉钉退出群聊会提示吗(钉钉退出群聊会显示吗)

    钉钉退出群聊会提示吗(钉钉退出群聊会显示吗)

  • 抖音取消关注会限流吗(抖音取消关注会退出粉丝团么)

    抖音取消关注会限流吗(抖音取消关注会退出粉丝团么)

  • 怎么设置qq电脑登录不用验证(怎么设置QQ电脑手机同步)

    怎么设置qq电脑登录不用验证(怎么设置QQ电脑手机同步)

  • 怎么下载快手上的视频(怎么下载快手呀)

    怎么下载快手上的视频(怎么下载快手呀)

  • 鼠标是通用的吗(鼠标能通用吗)

    鼠标是通用的吗(鼠标能通用吗)

  • 电子计算器上ce是什么意思(电子计算器上ce键的主要功能是关机对不对)

    电子计算器上ce是什么意思(电子计算器上ce键的主要功能是关机对不对)

  • 什么是淘宝会员名(什么是淘宝会员id)

    什么是淘宝会员名(什么是淘宝会员id)

  • 电脑windows7怎么升级win10(电脑windows7怎么恢复出厂设置)

    电脑windows7怎么升级win10(电脑windows7怎么恢复出厂设置)

  • 华为手机怎么倒计天数(华为手机怎么倒东西到苹果手机)

    华为手机怎么倒计天数(华为手机怎么倒东西到苹果手机)

  • 手机屏幕为什么失灵(手机屏幕为什么会变成紫色)

    手机屏幕为什么失灵(手机屏幕为什么会变成紫色)

  • 手机小圆点怎么弄出来(手机小圆点怎么关华为)

    手机小圆点怎么弄出来(手机小圆点怎么关华为)

  • uc浏览器隐藏相册在哪(uc浏览器隐藏相册怎么弄)

    uc浏览器隐藏相册在哪(uc浏览器隐藏相册怎么弄)

  • 闪送没人接单怎么办(闪送没人接单如何退还我费用)

    闪送没人接单怎么办(闪送没人接单如何退还我费用)

  • 华为watch2pro上市时间(华为手表新款watch2pro评测)

    华为watch2pro上市时间(华为手表新款watch2pro评测)

  • 准予扣除的税金及附加怎么算
  • 税控服务费全额抵扣增值税申报表中哪一栏
  • 公对公不开票怎么办
  • 增值税本期应补退税额为负数怎么处理
  • 固定资产可以计入实收资本吗
  • 非上市公司自然股权转让
  • 高新企业帐务流程
  • 进项票退回已抵扣税额
  • 补交以前年度的社保账务处理
  • 本月发放上月工资情况说明
  • 进销项税额的会计分录
  • 增值税实际缴纳总额
  • 实收资本印花税最新规定
  • 应交税费未交增值税明细账
  • 应计入增值税一般纳税人认定标准的“年应税销售额”
  • 信托保证本金吗
  • 公司车过户给个人流程
  • 圣伊利亚斯山
  • 免抵退税的账务处理
  • 小微企业所得税怎么算
  • 资产与负债的计税基础
  • 加拿大克卢恩国家公园
  • 来料加工业务的会计处理
  • 划入账户金额
  • nginx连接超时时间设置多少
  • mysql如何避免锁表
  • 股份有限公司都是私企吗
  • Sklearn GridSearchCV跑SVM很慢或卡死解决办法,SVM线性核函数卡死
  • nlp track
  • php 循环
  • php中常量
  • shift命令 向左移动参数
  • vue开发小技巧
  • 其他应收款检查表怎么填
  • 小企业短期借款科目的贷方登记
  • 发票税额打印不全可以入账吗
  • 帝国cms使用手册
  • 低值易耗品如何界定
  • 公章变更需要到哪个部门
  • 一般计税方法下自来水公司(一般纳税人)销售自来水
  • 金税开票系统
  • sql server2019实例功能的选择
  • mysql主从复制实现原理
  • 小规模纳税人和一般纳税人的区别
  • 本期销项税额怎么算
  • 什么人可以申请免税
  • 水电费没有收到怎么处理
  • 4s店送的赠品怎么样
  • 房地产公司房屋租赁管理办法
  • 提供劳务收入的确认条件
  • 哪些情况应收账款不能扣
  • 房产税减免退税怎么操作
  • 劳务派遣差额征税账务处理
  • 个人账户发工资扣税吗
  • 分公司账务处理需要注意哪些
  • 利润所属科目
  • Windows 8.1 with Update MSDN简体/繁体中文原版下载地址与安装密匙
  • centos重启动停在4m
  • 开发者学校
  • win8.1如何快速启动
  • Linux如何使用clash
  • JavaScript数组删除元素
  • css命名大全
  • 我决定放弃了你却对我笑了
  • 从零基础开始学
  • python字符串常用的五种方法
  • unity3d游戏开发书籍
  • unity动画animator
  • js打印命令
  • jQuery Easyui DataGrid点击某个单元格即进入编辑状态焦点移开后保存数据
  • Android mediaplayer 白屏
  • jquery增加一行和删除
  • 展示板效果图
  • 国家税务总局两江新区税务局
  • 税务稽查立案标准金额
  • 2021年留抵退税可以退2019年的吗
  • 实名办税人员承诺书范本
  • 实地税务稽查需注意什么
  • 客运站汽车票查询真伪
  • 国家税务总局广西壮族自治区税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号