浏览器插件开发-创建自己的启动页

前面说了怎么开发浏览器插件,今天继续说下怎么创建自己的启动页。

前不久在网上看到一个开源项目,某同学开发了一个聚合内容网站,很方便可以看到各个网站目前热点内容,地址是github.com/ourongxing/...

这不非常适合上班摸鱼嘛,于是借鉴其项目开发了一个启动页插件,就是摸摸鱼 - Chrome 网上应用店。该插件旨在替代浏览器默认的新标签页,聚合多个新闻、资讯来源的热点信息,让我们在工作、学习间隙快速获取信息流,实现高效"摸鱼"。

新建项目

老样子,还是使用wxt新建项目,

kotlin 复制代码
pnpm dlx wxt@latest init

配置新启动页

因为我们是要替换新标签页,将 Chrome 打开新标签页(New Tab Page, NTP)的行为覆盖,展示自定义的信息聚合界面。参考wxt开发文档,新建entrypoints/newtab/index.html。同样的,我们使用react,创建并应用app.tsx。

项目结构大概是

diff 复制代码
-entrypoints
  -newtab
    -index.html
    -main.tsx
    -App.tsx
    -Block.tsx
  
-package.json
-tsconfig.json
-wxt.config.ts

开发

现在就可以进行开发了。该同学的项目可以直接部署到cloudflare,我们创建一个cf pages进行部署。但我们仅能使用他的后端api,前端页面还需要继续编写。

  • 后端开发;我们在启动页地址明显跟后端接口不是同一个域名,需要跨域。但其原始接口没有处理跨域问题,我们需要稍加修改,兼容跨域。
  • 前端开发:参考其UI,简单使用NextUI创建前端页面,在app.tsx中请求接口并渲染,创建一个block.tsx渲染每个网站的热点新闻。

接下来运行调试pnpm dev ,wxt会自动启动一个浏览器并安装上插件,点击新建tab。最终整体效果如下

自动图标:chrome插件需要不同大小图标,比较繁琐。这次使用了一个新的插件@wxt-dev/auto-icons,可以自动生成不同尺寸的图标,非常方便。仅需在wxt.config.tx中新增相关配置即可:

yaml 复制代码
modules: ['@wxt-dev/module-react', '@wxt-dev/auto-icons'],
autoIcons: {
    baseIconPath: 'public/icon-512.png',
    grayscaleOnDevelopment: false,
    sizes: [16, 32, 48, 96, 128, 256, 512],
  },

总结

通过使用 wxt 框架,开发"摸摸鱼"这款 Chrome 新标签页插件的过程变得高效而愉快。wxt 自动化了许多繁琐的配置和构建工作,让开发者能更专注于核心功能的实现。

相关推荐
threelab14 小时前
Three.js 初中数学函数可视化 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
爱学习的程序媛14 小时前
浏览器工作原理全景解析
前端·浏览器·web
我是若尘15 小时前
用 Git Worktree 同时开多个需求,不用来回 stash
前端
IT_陈寒15 小时前
Vue的v-for为什么不加key也能工作?我差点翻车
前端·人工智能·后端
小碗羊肉15 小时前
【JavaWeb | 第十二篇】项目实战——登录功能
java·前端·数据库
一个处女座的程序猿O(∩_∩)O15 小时前
如何保持nginx配置与前端打包dist的路径保持一致、解决页面刷新白屏以及页面跳转问题
运维·前端·nginx
十有八七16 小时前
AI 开发,本质是一场文档的生命周期管理
前端·人工智能
Hyyy17 小时前
普通前端自救记录——第0周
前端
前端若水17 小时前
在 Vue 2 与 Vue 3 中使用 markdown-it-vue 渲染 Markdown 和数学公式
前端·javascript·vue.js
之歆17 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(下)
开发语言·前端·javascript·ecmascript