Chrome扩展数据通信实例

在开发过程中经常会遇到 background content_script 与popup三者间的通信
**下面介绍几种常见通信实例 **
1.content_script > background 多对一
content_script

chrome.runtime.sendMessage({saveurl:_url,savedata:data,msg:"save"}, function(response) {
        if(response.status){
            //成功    
        }else{
            //失败    
        }
});

background

chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) {
    if (request.msg){
        var msg = request.msg;
        switch (msg){
            case 'save':
                //可在此做一些服务请求
                ajax({
                    type:'post',
                    contentType: 'application/json; charset=utf-8',
                    url:request.saveurl,
                    data:request.adddata,
                    success:function(w){
                    if(w.code==200){
                        sendResponse({status:1,msg:"保存成功!"});
                    }else if(w.code == 401){
                        sendResponse({status:0,msg:"保存失败"});
                    }else{
                        sendResponse({status:0,msg:"保存失败"});
                    } 
                    return true;
                },
                error: function(xhr,info,e,){
                    sendResponse({status:0,msg:e});//例如服务器内部错误 503等         
                })
                //如果要用sendResponse 并在content_script接到响应值那么  return true  必须设定
                return true;  
                break;
        }
    }
})

该场景可用于解决 content_script的服务协议问题,例如 https网站中的 http服务请求问题,可放置在background中发请求

2.background > content_script 一对多
background

//需由popup等传入tab id 指定id后与content_script通信
this.sendErrorInfo= function(tabs,errorinfo){//错误提示
    chrome.tabs.sendMessage(tabs[0].id, {msg: "error_warn", errorInfo:errorinfo});
}

content_script

chrome.extension.onMessage.addListener(
        function(request, sender, sendResponse) {
            switch(request.msg) {
                case 'error_warn':
                    sendResponse({status:0});
                    return true;
                    break;
            }
        }
);

注:个人开发实践仅供参考,有不足和意见建议请在文章下方评论,多多指正和交流

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • chrome扩展开发入门教程 最近在开发chrome插件,看到一篇非常适合入门的教程,特记录一下 注:转载 本文首...
    谢大见阅读 11,503评论 1 25
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,359评论 19 139
  • Chrome扩展开发 标签(空格分隔): Chrome扩展 1、写在前面 Chrome插件是一个用Web技术开发...
    记忆的时间差阅读 11,223评论 0 15
  • 若无青丝三千根 若无口鼻眼耳舌 若无人生酸苦辣 若无今生是人生 也许来生我会是一棵树。
    陈三省之阅读 955评论 4 0
  • 好久没有自己做菜了,趁着今天买了排骨,做了一道红烧排骨,还是那个味道,没有变好,但也没有更坏。排骨洗净焯水,下锅炒...
    836a784a2482阅读 3,118评论 0 0