2 vainquit vainquit 于 2018.05.12 01:00 提问

a.js中executeScript给某tab注入b.js,b.js计算完的值怎么传回a.js中?

好像很多朋友都没有理解我的意思。。。其实我问的是关于executeScript的两个问题。因为executeScript有一个code参数和一个file参数,code是在当前页的js文件直接运行一段代码;而file是注入一个新的js文件,也就是我标题的意思。
1、chrome.tabs.executeScript(tb[0].id,{code:"abc(3)"},null);
……function abc(num){alert(num)}
这属于直接用code来在当前js文件运行一段代码,按照我的期望,它应该运行成功后就弹出窗口上面写个3,。但实际上它没有任何反映。我就很奇怪,code不是执行一段代码吗?为什么我不能执行同在a.js下的一个函数?莫非abc(3)这不能算代码吗?

2、chrome.tabs.executeScript(tb[0].id,{file:"b.js"},null);
这是我在标题问的问题。我在a.js中运行了以上代码,在一个tb[0]的tab插入b.js。而在b.js中计算出了一个变量值(假设为v),那么我如何将v传到a.js呢?要知道这个file:"b.js"仅仅只是注入了一段代码,可它并没有办法传值到b.js上。运用全局变量固然是个办法,可不到万不得已的时候,我不太想用,不知道大家有没有其他的解决办法。

4个回答

showbo
showbo   Ds   Rxr 2018.05.12 11:40
已采纳

用chrome.tabs.sendMessage和background js交互,具体参考这个:https://blog.csdn.net/summerxiachen/article/details/78698878

qq_41189681
qq_41189681   2018.05.12 08:53

你可以在一个页面引这两个JS,然后a.js获取到的数据放在一个公共变量里面b.js就可以获取到或者直接吧这个值当做参数传递个b.js的方法。

vainquit
vainquit 这问题就是如何把值当做参数传给b.js的方法。。。因为excuteScript的file:"b.js"并没有传值的功能的,仅仅只是注入b.js吧?
3 个月之前 回复
weixin_36485263
weixin_36485263   2018.05.12 06:48

比方说如果你想看到在网站http://www.example.com里面的一个警告框,那么首先在地址栏输入URL(www.example.com),当页面加载完之后,清空URL并输入javascrit:alert("Hello World")作为一个新的URL.这样将弹出一个警告框显示Hello World.可是,一些人会用这个技巧改变页面内的几乎任何内容

a718089112
a718089112   2018.05.12 08:25

使用方式:{code:abc(3)}
b.js 加个return 啊 把结果直接return返回 那样 abc(3) 直接就是结果了

vainquit
vainquit 可是注入b.js的代码不是file:"b.js"嘛。。这样就无法引用函数了
3 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
jquery a.js调用b.js的方法
在a.js中加入  $(function () {     //引入 b.js文件     var js_element = document.createElement("script"); //这句是创建一个script标签     js_element.setAttribute("type", "text/javascript"); //脚本用的是javascript     js
一个B.js获取另一个A.js的方法,只要将在html页面中的载入顺序将A.js放在B.js前即可
-
a.js调用b.js里面的方法
在调用之前,引入如下4行代码即可new_element=document.createElement("script"); new_element.setAttribute("type","text/javascript"); new_element.setAttribute("src","b.js");document.body.appendChild(new_element); 分析:利用do
关于JavaScript的执行顺序,如果多个js中(a.js,b.js,c.js)都有一个方法(如test方法),那么如果再html中触发执行该test方法,是执行的那个js中的test方法(a.)?
关于JavaScript的执行顺序,如果多个js中(a.js,b.js,c.js)都有一个方法(如test方法),那么如果再html中触发执行该test方法,是执行的那个js中的test方法? 是a.js的?b.js的?还是c.js? 答案是: 那个js最后被加载入内存,则执行哪个,因为后被载入内存的js文件中的test方法会将之前的js文件的test方法覆盖掉。 如果加载
NodeJs学习之路(1)
NodeJs主要干的工作 nodejs主要可以完成的工作就是在Web场景下使用,是对前端最友好的后端语言,主要是在高并发,非阻塞I/O密集下使用,但是不适合CPU使用密集、非阻塞I/O不多的情况下使用。很多情况下NodeJS在性价比方面不是最好的,但是对于前端开发者而言python和java语言并不是太友好。。。学习成本高,后台也并不是太清楚前端,也懒得写(哈哈哈主要是这个)。而Node
JS中跨页面调用变量和函数(例如a.js 和 b.js中互相调用)
在项目开发过程中,也许你会遇这样的情况。在某一Js文件中需要完成某一功能,但这一功能的大部分代码在另外一个Js文件中已经完成了,自己只需要调用这个方法再加上几句代码就可以实现所需的功能。我们知道,在html中,利用引入的两个js是不可以相互调用的。那么该如何解决呢?当然,你可以将代码通通copy过来,也许你并不喜欢这样。    例如有这样一个html,里面有一个按钮,当按下时调用b.js文件
饿了么大前端 Node.js 进阶教程
饿了么大前端 Node.js 进阶教程 因为 2016 年面试了很多做 Node.js 的同学,发现大部分做 Node 的同学都是前端转过来的,对后端的知识大多一片空白。所以很难招到比较好的 Node.js 服务端程序员(注意,不是全栈)。 于是出于我们一贯的开源与分享精神,我们筹备了这个名字叫《如何通过饿了么 Node.js 面试》的开源的 Node.js 进阶教程。 gith
页面传值不交互:JS存储数据之LocalStorage用法
本人的需求是一个页面传值给另外一个页面,但是不需要交互: A页面设置LocalStorage:     if(!window.localStorage){             alert("浏览器不支持localstorage");      }else{             var storage=window.localStorage;             loca
js文件中引用其他js文件
在a.js中需要用到b.js中的方法,所以需要在a.js中引用b.js文件,js不提供类似java中import的导包语句所以只能添加元素到html文档,方法如下: 在a.js文件中写 方法一: document.write(""); 方法二:
cocos2d-js使用的对象
1、把A对象添加到B对象中:B对象.addchild(A对象) 2、数组中变量名后面不需要维度[] 3、定义变量对象时使用类型符var 4、精灵cc.Sprite、层cc.Layer、Menu按钮cc.MenuItemLabel、文字显示cc.LabelTTF、菜单cc.Menu、精灵按钮cc.MenuItemSprite、图片按钮cc.MenuItemImage、开关按钮cc.MenuIt