- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 React/Redux 开发 Chrome 扩展。为此,我使用 Webpack,现在使用 WebPack DLLReference 插件将一些资源迁移到单独的文件中,以优化构建过程。
然后我需要将生成的 dll/dll.vendor.js 加载到我的弹出窗口和注入(inject)内容中。对于弹出窗口,它工作正常,但它不适用于注入(inject)的内容。
我已将其添加到 list 中
"web_accessible_resources": [
"dll/dll.vendor.js"
],
文件就在那里,我什至可以使用以下路径访问它:chrome-extension:///dll/dll.vendor.js
但它不存在于注入(inject)的内容中,正如我可以看到打开开发者工具 -> 源当然,这会在稍后生成丢失对象的错误。
在迁移到 DLLReferencePlugin 之前一切正常。
我的 DLL webpack 配置文件:https://pastebin.com/z9RjRUqm
我的内容 webpack 配置文件:https://pastebin.com/0Niw2Fqm
触发错误的行:
module.exports = vendor;
如果我检查弹出窗口,它有相同的行,如果我在那里设置断点并观察它定义的变量,问题只发生在内容中。
将我的扩展工具栏注入(inject)页面的代码:内容/src/index.js
import React from 'react';
import {render} from 'react-dom';
import {Provider} from 'react-redux';
import {Store} from 'react-chrome-redux';
const anchor = document.createElement('div');
anchor.id = 'my-anchor';
document.body.appendChild(anchor)
const vendorUrl = chrome.runtime.getURL("dll/dll.vendor.js")
render(
<Provider store={proxyStore}>
<div>
<script src={vendorUrl}></script>
<link id='semantic-ui' rel='stylesheet' type='text/css'
href='https://cdnjs.cloudflare.com/ajax/libs/semantic-ui/2.2.2/semantic.min.css' media='all' />
<AppContainer>
<ToolbarContent />
</AppContainer>
</div>
</Provider>
, document.getElementById('my-anchor'));
您知道造成此问题的其他原因吗?有更好的方法来调试资源为何不可用于内容环境吗?
更新
根据我最后的发现,发生这种情况是因为依赖于 dll.vendor 的代码是在页面上发生注入(inject)之前执行的,但我不知道如何避免这种情况发生。
最佳答案
您对内容脚本的理解中缺少一件事,即 Isolated World paradigm :
Content scripts execute in a special environment called an isolated world. They have access to the DOM of the page they are injected into, but not to any JavaScript variables or functions created by the page. It looks to each content script as if there is no other JavaScript executing on the page it is running on. The same is true in reverse: JavaScript running on the page cannot call any functions or access any variables defined by content scripts.
这有什么关系?好吧,如果您要添加 <script>
元素到页面的 DOM,代码将在页面的上下文中执行 - 而不是内容脚本的上下文。这种技术称为"page level" or "injected" scripts .
但是,这不是您想要的。您希望它位于内容脚本上下文中,以便您可以使用库。然后你有选择:
如果您始终需要相同的脚本配置,那么将脚本作为数组添加到 list 中可能是最好的选择。加载顺序很重要:
"js" : [ "library.js", "actual_code.js" ]
如果您出于某种原因需要在运行时从现有内容脚本动态加载代码,您可以向inject it programmatically请求后台页面。为你。如果您已经这样做了,只需按正确的顺序链接调用即可。
这不是技术上理想的解决方案,但您可以 XHR 您的内部资源,然后 eval()
来自内容脚本上下文。
关于javascript - Chrome 扩展程序 : Resource not available even adding it in web_accessible_resources,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44287425/
我正在寻找外行人对计算机硬件和组织的介绍。以下是我想讨论的一些主题。 Brief intro to electronics. Gates and state machines, intro to re
有没有人在 Visual Basic 2010 中看到过这个错误,如果有的话......关于如何解决它的任何想法? 错误是 module 'Resources' and module 'Resourc
这个问题在这里已经有了答案: Why ?attr/colorAccent dose not work below lollipop version? (2 个答案) 关闭 5 年前。 我收到以下错误
我正在尝试通过 ring 学习 clojure 网络开发和 compojure我有点不清楚 compojure.route/resources 和 ring.middleware.resource/w
是否必须放置内部 try-with-resources 或其中一个 try-with-resources 中的所有内容都会自动关闭? try (BasicDataSource ds = Bas
我有一本包含多个食谱的 Chef 食谱,用于安装服务。 Chef-client 的工作方式是每 15 分钟(或其他固定时间间隔)重新收敛一次。现在我的食谱的第一步是停止服务,所以服务将每 15 分钟停
我有资源组“MyResources”,其中包含 4 个资源: AppService - 我的服务器, AppServicePlan - MyServerWestEuFarm, ApplicationI
我有资源组“MyResources”,其中包含 4 个资源: AppService - 我的服务器, AppServicePlan - MyServerWestEuFarm, ApplicationI
我有一个返回 ResponseEntity 的休息终点. 需要检查如何在 Swagger 规范中创建这种类型的响应。这里包中的资源是 org.springframework.core.io.Resou
In my azure portal I have 6 separate applications, I have to list all of the employed resources u
In my azure portal I have 6 separate applications, I have to list all of the employed resources u
我有一个问题,设计师不会显示表单。它失败,错误 Designer 给出警告,如下所示: 我该如何解决这个问题? 最佳答案 您似乎缺少在应用程序中加载此表单所需的项目 资源 . 您可以访问 资源右键单击
我是 angularJS 世界的新手,我可能误解了一些东西。 我的应用程序使用 Controller 、指令和服务,所有这些都运行完美,直到我使用带有 $resource 的服务,然后出现“冲突”或其
我在 Unity3D 工作。 我使用 Resources.LoadAll(path);加载文件夹和子文件夹中的所有项目。执行此操作后,我想获取对象的子文件夹名称或完整路径。这可能吗? 并且不建议使用
我需要监控每个客户端环境(一个订阅、多个资源组)的 Azure 支出。在我的研究中,我发现了 2 个可以使用的 API: 资源费率卡( https://msdn.microsoft.com/fr-fr
在 RDF 1.1 XML 语法文档中 rdf:resource 在定义 Empty Property Elements 时用作缩写形式: When a predicate arc in an RDF
这是一种常见的情况,我们需要在用户更新/创建一些数据后向用户显示错误/成功消息,我们如何在 AngularJS 中实现它? 我想添加回调但找不到解决方案。使用 $http.post().success
我正在使用 android studio 作为 IDE 开发一个 android 应用程序。 我的问题是: 如何在构建APK过程中排除某个目录下的某些文件? 在我的例子中,我想从构建中排除一些图像,因
在编译我的 Visual Studio C# 项目时,出现以下错误: 在“Resources”参数中多次指定项目“obj\Debug\SampleProject.Forms.MDIMain.resou
使用 CoffeeScript、Angular 和 $resource,我创建了以下工厂: angular.module('myapp', ['ngResource']).factory 'MyObj
我是一名优秀的程序员,十分优秀!