热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在Chrome扩展程序中使用Require.JS时触发chrome.runtime.onInstalled

如何解决《如何在Chrome扩展程序中使用Require.JS时触发chrome.runtime.onInstalled》经验,为你挑选了1个好方法。

我在安装扩展程序时执行一些设置代码时遇到问题.我正在使用Chrome开发者网站建议的chrome.runtime.onInstalled,但它没有解雇.似乎这个问题与Require.JS的使用有关.这是我的代码:

requirejs.config({...});// i'll not reproduce the whole config here for brevity

// Define the Global Object that will hold the extension functionality
var EXT = EXT || {};

// Start the main app logic.

requirejs(['chrome.storage', 'chrome.settings', 'chrome.tabs'],
function (chromeStorage, chromeSettings, chromeTabs) {
    'use strict';

    var getLocalRepos;

    /**
     * Executes the callback with an array of repositories as the parameter.
     * @param {function} callback
     */
    getLocalRepos = function (callback) {
        'use strict';

        chromeStorage.get('localRepos', callback);
    };

    // Take care of the extension lifecycle.
    chrome.runtime.onInstalled.addListener(function (details) {
        "use strict";

        // Create dummy data to populate the local storage for testing purposes.
        var dummyData = [
            {
                name: 'repo1',
                description: 'description1',
                username: 'reydel',
                age: 'theAge'
            },
            {
                name: 'repo2',
                description: 'description2',
                username: 'reydel',
                age: 'theAge'
            }
        ];

        switch (details.reason) {
            case 'install':
                chromeStorage.set({ localRepos: dummyData }, function () {
                    // Do nothing
                });
                break;
        }
    });

    // Bind all functions to an object in the Global Space to make them accessible from the outside scripts
    // referencing the BackgroundPage object
    window.EXT.getLocalRepos = getLocalRepos;
});

我在控制台中使用了监听器回调中的代码并且它可以工作,只是事件没有被触发.

关于如何解决这个问题的任何想法?有人以前做过吗?



1> Rob W..:

chrome.runtime.onInstalled加载代码后会直接触发该事件.当您异步添加事件侦听器onInstalled时,在添加事件侦听器时已分派事件.

要解决此问题,您必须使应用程序的初始化同步.不幸的是,require.js被设计为异步脚本加载器.修改此库以使其同步是可能的,但是浪费了努力而没有任何好处.

要在Chrome扩展中使用require-style模块(AMD),我强烈建议使用将脚本(例如r.js或grunt-contrib-requirejs)和almond.js组合为脚本加载器的中间构建步骤.相反,require.js,almond.js 支持同步加载.

这是一个配置示例,您可以使用它来构建一个名为all.jsalmond.js(作为脚本加载器)的单个文件,并mymain.js用作入口点(主脚本):

({
    name: 'mymain',
    out: 'all.js',
    include: [
        'almond'
    ],

    skipModuleInsertion: true,
    wrap: {
        start: '(function(){',
        // true = load synchronously. This is a feature of almond.js
        end: 'require(["mymain"], null, null, true);})();'
    }
})

为了避免命名空间污染,我将代码包装在一个立即调用的函数表达式中.如果您希望模块在全局命名空间中可用(例如,用于调试),只需删除(function(){})();.

有关这些配置选项(以及更多)的文档,请参阅https://github.com/jrburke/r.js/blob/master/build/example.build.js.


试试前面的例子:

    安装r.js:npm install -g requirejs

    将以前的配置保存为 myfancyname.build.js

    创建一个名为的脚本mymain.js:define(function() { ... });.
    (这是一个没有依赖关系的简单模块定义.如果要了解有关其他类型模块的更多信息,请阅读require.js文档,例如具有依赖关系的模块).

    运行r.js编译文件: r.js -o myfancyname.build.js

    现在,您all.js可以加载一个可以加载的文件,例如"background": { "scripts": ["all.js"] }在Chrome扩展程序的清单文件中使用.


推荐阅读
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文探讨了如何解决在使用CoffeeScript定义类时,实例化后对象为空的问题,并提供了解决方案。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 本文探讨了在使用Knockout.js创建自定义绑定处理器时遇到的一个常见问题:尽管两个绑定使用了相同的初始化代码并绑定到了同一个值,但它们的初始化表现却不同。 ... [详细]
  • 本文详细探讨了JavaScript中的闭包与柯里化技术,这两者是函数式编程的重要组成部分,对提升代码的灵活性和可维护性具有重要作用。 ... [详细]
  • 探讨在特定情况下使用 Knockout.js 的 if 或 visible 绑定的最佳实践,特别是在处理未定义对象时的策略。 ... [详细]
  • 我在一个标签中嵌入了一个地图,如何设置使其“map_canvas”在标签下的宽度和高度都达到100%? ... [详细]
  • 本文探讨如何在VueJS项目中通过配置vue.config.js文件实现多页面应用(MPA),特别是针对管理端和客户端的不同需求。 ... [详细]
  • 本文详细介绍了利用JavaScript实现的五种不同的网页弹出窗口技术,包括全屏窗口、全屏模式窗口、带收藏链接工具栏的窗口、网页对话框及HTA窗口。 ... [详细]
  • 本文深入探讨了JavaScript中循环结构的使用方法,特别是While循环,用于重复执行一段代码直到特定条件不再满足。同时,文章还介绍了Switch语句在多条件分支选择中的应用。 ... [详细]
author-avatar
弹指一点红
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有