Chrome插件开发:在网页上运行脚本

金金金上线!

话不多,只讲你能听懂的前端知识

概览

  • 本教程将构建一个扩展程序,用于向任何 Chrome 扩展程序和 Chrome 应用商店文档页面添加预计阅读时间

构建扩展程序

  • 创建一个名为 reading-time 的新目录来存放扩展程序的文件

添加扩展程序的相关信息

  • 清单 JSON 文件是唯一的必需文件。其中包含有关扩展程序的重要信息。在项目的根目录 中创建一个 manifest.json 文件,并添加以下代码:

    json 复制代码
    {
      "manifest_version": 3,
      "name": "Reading time",
      "version": "1.0",
      "description": "Add the reading time to Chrome Extension documentation articles"
    }
    1. 它必须位于项目的根目录
    2. 唯一的必需键是 "manifest_version""name""version"
    3. 它在开发期间支持注释 (//),但您必须先移除这些注释,然后才能将代码上传到 Chrome 应用商店。

提供图标

  • 那么,为什么需要图标?虽然在开发过程中图标是可选的,但如果打算在 Chrome 应用商店中分发扩展程序,则必须提供图标。它们还会显示在扩展程序管理页面等其他位置。
  • 创建一个 images 文件夹,并将图标放入其中(自行下载就好):

声明内容脚本

  • 扩展程序可以运行脚本,以读取和修改网页内容。这些脚本称为内容脚本 。它们位于隔离的世界中,这意味着它们可以更改自己的 JavaScript 环境,而不会与其托管页面或其他扩展程序的内容脚本发生冲突。

  • 将以下代码添加到 manifest.json 以注册名为 content.js 的内容脚本:

    json 复制代码
    "content_scripts": [
        {
          "js": ["scripts/content.js"],
          "matches": [
            "https://developer.chrome.com/docs/extensions/*",
            "https://developer.chrome.com/docs/webstore/*"
          ]
        }
      ]

    "matches" 字段可以有一个或多个匹配模式。这些标记可让浏览器确定要将内容脚本注入哪些网站。匹配模式由以下三个部分组成:<scheme>://<host><path>。可以包含"*"字符。

计算并插入阅读时间

  • 内容脚本可以使用标准文档对象模型 (DOM) 读取和更改网页内容。该扩展程序首先会检查网页是否包含 <article> 元素。然后,它会统计此元素中的所有字词,并创建一个段落来显示总阅读时间。

    在名为 scripts 的文件夹中创建一个名为 content.js 的文件,然后添加以下代码:

    js 复制代码
    function renderReadingTime(article) {
      // If we weren't provided an article, we don't need to render anything.
      if (!article) {
        return;
      }
    
      const text = article.textContent;
      const wordMatchRegExp = /[^\s]+/g; // Regular expression
      const words = text.matchAll(wordMatchRegExp);
      // matchAll returns an iterator, convert to array to get word count
      const wordCount = [...words].length;
      const readingTime = Math.round(wordCount / 200);
      const badge = document.createElement("p");
      // Use the same styling as the publish information in an article's header
      badge.classList.add("color-secondary-text", "type--caption");
      badge.textContent = `⏱️ ${readingTime} min read`;
    
      // Support for API reference docs
      const heading = article.querySelector("h1");
      // Support for article docs with date
      const date = article.querySelector("time")?.parentNode;
    
      (date ?? heading).insertAdjacentElement("afterend", badge);
    }
    
    renderReadingTime(document.querySelector("article"));

测试是否生效

加载扩展程序,访问:developer.chrome.com/docs/extens...

  • 这样便是成功了

编写有误还请各位指正,万分感谢

相关推荐
Null15512 小时前
浏览器唤起桌面端应用(进阶篇)
前端·浏览器
Null15515 小时前
浏览器唤起本地桌面应用(基础版)
前端·浏览器
LongtengGensSupreme4 天前
后端设置了跨域但是还是提示跨域问题,原因是这里有两个独立的安全策略在起作用:Chrome和Edge浏览器安全策略强制修改方案
前端·chrome·edge·浏览器·跨域
明远湖之鱼7 天前
从代码到像素:浏览器渲染原理与 React Fiber 架构的深度协作
前端·react.js·浏览器
天天扭码13 天前
以浏览器多进程的角度解构页面渲染的整个流程
前端·面试·浏览器
LYFlied14 天前
浏览器渲染图层详解
前端·性能优化·图形渲染·浏览器
卤代烃14 天前
🦾 可为与不可为:CDP 视角下的 Browser 控制边界
前端·人工智能·浏览器
程序员小易21 天前
前端轮子(2)--diy响应数据
前端·javascript·浏览器
八哥程序员25 天前
Chrome DevTools 详解系列之 Elements面板
javascript·浏览器
Bigger25 天前
后端拒写接口?前端硬核自救:纯前端实现静态资源下载全链路解析
前端·浏览器·vite