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

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

  • iphone12如何开启画中画(iPhone12如何开启高清通话)

    iphone12如何开启画中画(iPhone12如何开启高清通话)

  • 如何远程查看别人微信(如何远程查看别人手机)

    如何远程查看别人微信(如何远程查看别人手机)

  • p30pro指纹识别不灵敏(p30pro指纹识别不见了)

    p30pro指纹识别不灵敏(p30pro指纹识别不见了)

  • 快手小黄车多久可以提现(快手小黄车多久收益,多久提现)

    快手小黄车多久可以提现(快手小黄车多久收益,多久提现)

  • 平板电脑可以用先锋影音吗(平板电脑可以用ps软件吗)

    平板电脑可以用先锋影音吗(平板电脑可以用ps软件吗)

  • 华为手机出现volte怎么关闭(华为手机出现voice图标)

    华为手机出现volte怎么关闭(华为手机出现voice图标)

  • ps加选减选快捷键(ps加减选区快捷键是什么)

    ps加选减选快捷键(ps加减选区快捷键是什么)

  • 淘宝称昵怎么修改(淘宝昵称如何修改)

    淘宝称昵怎么修改(淘宝昵称如何修改)

  • 二手苹果无面容什么意思(二手苹果无面容能买吗)

    二手苹果无面容什么意思(二手苹果无面容能买吗)

  • 拼多多销量多久清一次(拼多多销量多久清零)

    拼多多销量多久清一次(拼多多销量多久清零)

  • 华为p40怎么返回主屏幕(华为p40怎么返回主菜单)

    华为p40怎么返回主屏幕(华为p40怎么返回主菜单)

  • 华为ELSAN00是什么手机(华为elsan00是什么型号多少钱)

    华为ELSAN00是什么手机(华为elsan00是什么型号多少钱)

  • word表格居中不在中间(word表格居中不在正中,偏右)

    word表格居中不在中间(word表格居中不在正中,偏右)

  • 苹果11屏幕自动变暗(苹果11屏幕自动亮怎么关闭)

    苹果11屏幕自动变暗(苹果11屏幕自动亮怎么关闭)

  • 手机不玩也耗电怎么解决(手机不玩也耗电怎么解决OPPO)

    手机不玩也耗电怎么解决(手机不玩也耗电怎么解决OPPO)

  • 8p相机九宫格怎么开(苹果8怎么九宫格拍照)

    8p相机九宫格怎么开(苹果8怎么九宫格拍照)

  • hive sql和mysql区别(hive和mysql的区别)

    hive sql和mysql区别(hive和mysql的区别)

  • 滴滴用户评价怎么评(滴滴司机的评价在哪里)

    滴滴用户评价怎么评(滴滴司机的评价在哪里)

  • 微信被骗怎么办(网上诈骗24小时内能找回)

    微信被骗怎么办(网上诈骗24小时内能找回)

  • 电脑微信的聊天记录是哪个文件夹(电脑微信的聊天记录怎么彻底删除)

    电脑微信的聊天记录是哪个文件夹(电脑微信的聊天记录怎么彻底删除)

  • linux强制删除文件教程(linux强制删除文件夹)

    linux强制删除文件教程(linux强制删除文件夹)

  • Windows11怎么设置中文输入法?Win11中文输入法设置教程(windows11怎么设置ipv4地址)

    Windows11怎么设置中文输入法?Win11中文输入法设置教程(windows11怎么设置ipv4地址)

  • cutftp.exe进程信息查询 cutftp是什么进程(进程process)

    cutftp.exe进程信息查询 cutftp是什么进程(进程process)

  • yolov5损失函数详解【附代码】(yolo4损失函数)

    yolov5损失函数详解【附代码】(yolo4损失函数)

  • 【大数据实时数据同步】超级详细的生产环境OGG(GoldenGate)12.2实时异构同步Oracle数据部署方案(上)(大数据实时数仓)

    【大数据实时数据同步】超级详细的生产环境OGG(GoldenGate)12.2实时异构同步Oracle数据部署方案(上)(大数据实时数仓)

  • 企业合并债权如何处理
  • 小规模纳税人宾馆房屋租赁税率
  • 计提并结转所得税费用的会计分录
  • 银行开具的票据怎么查询
  • 办税人是纳税人吗
  • 税务师考试报名
  • 汇总记账凭证会计核算形式与科目汇总表
  • 固定资产出售如何申报增值税
  • 季度残保金如何申报
  • 企业开办费可不交税吗
  • 收入入账会计分录
  • 当月开票当月收款
  • 将固定资产转给母公司属于债务重组吗
  • 企业股权转让影响利润吗
  • 资本公积转为实收资本会计等式
  • 租房的装修费怎么入账
  • 跨年度销售退回所得税
  • 职工的大病医保怎么报销
  • 增值税出口退税计入什么科目
  • 个人设备租赁给公司怎么提供发票
  • 有限公司缴税
  • 吊车费计什么科目
  • 土地出让金为何写有效期
  • 开模具公司要什么设备
  • 公司扣了员工的个人所得税但没有帮员工申报
  • 固定资产 盘点
  • 小型纳税人个人所得税
  • 出口退税和增值税抵扣一样吗
  • 一般劳务报酬和其他劳务报酬的区别
  • 怎么解决win11系统不兼容问题
  • windows11启动卡在转圈圈
  • win10锁屏壁纸自动更新
  • jQuery+Ajax+PHP“喜欢”评级功能实现代码
  • 收入成本科目
  • 调制解调器的作用包括
  • php目录结构
  • 原材料结转成本有几种方法
  • 资本金投资回报率
  • 农产品来料加工设备
  • 全局函数使用
  • 2022年 change detection遥感图像变化检测 论文附代码
  • 面试题集锦
  • 华为云从入门到实战电子版
  • 新企业所得税季初资产总额怎么填
  • 税控盘全额抵扣发票怎么勾选
  • 个体工商户个税优惠政策2023
  • 专用发票能当月抵扣吗
  • 职工教育经费扣除限额怎么算
  • 自动执行python
  • 多收了钱怎么记账
  • 股东分红方式如何约定
  • 利润表和资产负债表
  • 固定资产分期付款会计处理?
  • 一般纳税人作废发票的流程
  • MySQL 5.7 create VIEW or FUNCTION or PROCEDURE
  • sql server基本知识
  • 什么是财产行为税举例
  • 股票买卖怎么操作
  • 行政单位现金管理
  • 查补以前年度所得税
  • 固定资产清理会计处理
  • 企业亏损为什么还继续
  • 购买的材料入库属于什么会计科目
  • abc类企业的划分
  • 装订好的凭证可以拿掉一页吗
  • linux系统中怎么输入中文
  • win7桌面提示7601
  • winxp如何增加c盘空间
  • win7系统的电脑能装win10吗
  • win8.1专业版怎么升级成win10
  • Centos7 中 Node.js安装简单方法
  • 关于shell的说法,不正确的是
  • python绘制球面
  • cocos2dx 2.2.2
  • 怎么配置nodejs的环境
  • jquery判断div是否为空
  • 用jquery写注册界面
  • 医保报销是按自然年计算吗
  • 福州台江区怎么去
  • 国,地税纳税申报表是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设