javascript - 捆绑的 Webextension 看不到 JQuery

标签 javascript webpack google-chrome-extension browserify parceljs

我正在为 Chrome 创建一个网络扩展,以下代码会导致错误:

$(function () {
  $('[data-toggle="popover"]').popover();
  // ...
});

Chrome 提示:

Uncaught TypeError: jquery_1.default(...).popover is not a function

看起来 Bootstrap 根本不可用。我知道脚本的导入顺序很重要:Chrome extension "$ is not defined" error

所以我确保 bootstrap 包含在我的代码之前:

"content_scripts": [
    {
        "js": [
            "assets/jquery/dist/jquery.min.js",
            "assets/popper.js/dist/popper.min.js",
            "assets/bootstrap/dist/js/bootstrap.min.js",
            "content/index.js"
        ],
        "css": [
            "assets/css/extra.css",
            "assets/bootstrap/dist/css/bootstrap.min.css"
        ]
    }
],

这些脚本路径有效。

编辑:

抱歉,我弄乱了这个错误的文档。 显然,只有当我使用 bundler (例如包裹)时才会发生这种情况。 我只使用 Parcel 进行了测试,但我相信任何捆绑管理器都会出现此问题,例如 webpack 或 browserify。

最佳答案

我在使用 Bootstrap 4 时遇到了同样的问题,它在 Bootstrap v.3.3.7 上运行良好,但我无法让它工作,但最终我做到了。这就是我所做的:

CDN 订单:

<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">

<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>

<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>

<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>

示例函数:

$(function () {
    $('[data-toggle="popover"]').popover()
})

示例 HTML:

<a href="#" title="Header" data-toggle="popover" data-placement="bottom" data-content="Content">Bottom</a>

可能值得确保您拥有 Bootstrap/jQuery/Popper 等的所有最新版本,并将它们按照与上面相同的顺序放置:

bootstrap.css
jquery-3.3.1-slim.min.js
popper.js
bootstrap.min.js

希望这有帮助 - 如果没有帮助,请告诉我

关于javascript - 捆绑的 Webextension 看不到 JQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52990720/

相关文章:

javascript - Webpack 如何独立打包 JS 和 CSS 文件?

javascript - innerHTML 不更新文本

JavaScript onkeydown 不起作用

c# - 解决使用 js 和 C# 提取日期的问题

javascript - 为什么不能使用 VueJS 在 vue.config.js 文件中使用 ES 导入?

node.js - Express 抛出 404 url​​ 中是否有点 - Vue、webpack

google-chrome-extension - 迁移 Chrome 扩展 v3 通知

javascript - 用于解析和标记文本文件的浏览器扩展

javascript - 在 Chrome 扩展程序中安全存储 Django REST API token

javascript - 使用 Ionic 制作签名绘图板