tabs.onUpdated.addListener的changeInfo.status从未定义到完成而不需要加载 [英] tabs.onUpdated.addListener's changeInfo.status goes from undefined to Complete without ever going to loading

查看:278
本文介绍了tabs.onUpdated.addListener的changeInfo.status从未定义到完成而不需要加载的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

只有当google SERP网页加载时(从google.com/上的搜索框或SERP网页上的搜索框中进行搜索时),我才会看到此行为。我看到其他网页的预期行为,也就是我看到的是未定义的,加载和最后一个完整的。

  chrome.tabs.onUpdated。 addListener(function(tabId,changeInfo,tab){
console.log(changeInfo.status); //打印未定义的几次然后完成(没有加载的迹象)
}



$ p

同样刷新SERP页面会触发加载和完成状态。


< Firefox和Google Chrome是不同的浏览器,WebExtensions对于Firefox来说是非常新的,即使它已经成熟,Firefox和Google Chrome也会有所不同。对于您的扩展应该运行的各种浏览器,代码段有明显不同的部分。

目前在Firefox中, changeInfo object这是传递给监听器函数的 chrome.tabs.onUpdated 可能无效。它应该只有两个可能的值正在载入已完成



似乎有一个错误,使得 changeInfo 可以具有属性 status ,但是该属性的值是未定义。在这些情况下, 标签.Tab 对象也传递给 tabs.onUpdated 监听器有一个属性 status 那是一个字符串。在大多数情况下,这个值是'completed',即使看起来不太准确。



看起来像这样的可以相对容易地工作。这取决于你需要什么。

下面的代码将会覆盖 undefined 值> changeInfo.status 假设它们是'loading'

  chrome.tabs.onUpdated.addListener(function(tabId,changeInfo,tab){
if(changeInfo.hasOwnProperty(status)&&typeof changeInfo.status === 'undefined'){
changeInfo.status ='loading';
}
});

现实情况是,您需要确定自己的扩展功能。 Firefox和Chrome会给你的扩展提供不同的信息。

对于您所描述的情况(Google主页为 SERP 页面)合并的 webRequest webNavigation tabs.onUpdated 事件会为您提供以下信息:

  webRequest:https://www.google.com/images/nav_logo242.png 
webRequest:https://www.google.com/complete/search? sclient = PSY-AB&安培;站点=安培;源= HP&安培; q = SERP&安培; OQ =安培; gs_l =安培; PBX = 1&安培; BAV = on.2,或&安培; BVM = bv.129759880,d.cGc&安培; FP = 1&安培; BIW = 1256&安培;波黑= 924&安培; DPR = 1&安培; PF = p与M. gs_rn = 64&是p; gs_ri = psy-ab& cp = 4& gs_id = kv& xhr = t& tch = 1& ech = 1& psi = E6u2V_S8BY_gjwPakICACA.1471589139270.1
webRequest:https://www.google.com/gen_204 ?atyp = i& ct = 1& cad = 1& rsm = 6& ei = E6u2V_S8BY_gjwPakICACA& zx = 1471589794481

tabs.updated event:tabId = 37 :: changeInfo keys:status :: changeInfo。 status = undefined(override-> loading)
tab.status = complete(override-> loading)testTabEvents.js:96:9
$ b $ tabs.updated event:tabId = 37: :changeInfo keys:status,url :: changeInfo.status = complete
tab.status = complete
tab.url = https://www.google.com/?gws_rd = ssl#q = SERPtestTabEvents。 js:96:9

webRequest:https://www.google.com/search?sclient=psy-ab&site=&source=hp&q=SERP&oq=SERP&gs_l = hp.3..0i3k1j0l3.655013.655013.0.657681.1.1.0.0.0.0.173.173.0j1.1.0 .... 0 ... 1c.1.64.psy-ab..0.1.163.LqQ90ZRWj7o&安培; PBX = 1&安培; BAV = on.2,或&安培; BVM = bv.129759880,d.cGc&安培; FP = 1&安培; BIW = 1256&安培;波黑= 924&安培; DPR = 1&安培; TCH = 1&安培; ECH = 1& psi = E6u2V_S8BY_gjwPakICACA.1471589139270.3

webNavigation-> ReferenceFragmentUpdated:tadId = 37 :: url = https://www.google.com/?gws_rd = ssl#q = SERPtestTabEvents.js: 182:13

tabs.updated event:tabId = 37 :: changeInfo keys:status :: changeInfo.status = undefined(override-> loading)
tab.status = complete(override - > loading)testTabEvents.js:96:9

tabs.updated event:tabId = 37 :: changeInfo keys:status :: changeInfo.status = undefined(override-> loading)
tab.status =完全(override-的载量)testTabEvents.js:96:9

的WebRequest:数据:图像/ PNG; BASE64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAJCAYAAAAGuM1UAAAAaUlEQVR4AY3OxQECQRBE0YdHsyc0G9LihkNqOESA92n9j09LlaCnmEzOFGcMFBCxc + Ra44UjElmSiL0iVxOL + LhjLIj7PWIzNCBd9MAk1iObHKCNfSTcYr2wQ0uWjFKmc0VRJNekXWTjDe6gHTKFP5vkAAAAAElFTkSuQmCC
的WebRequest: https://id.google.com/verify/NQAAAB8aqx-h_1Es5zxXakqEQ4VnEYZCXpWW_8Rmrl4pN1yV-s-1d_qg6kBSbexs0XcddYBKPk8NAwLOwyJ-W75hWEw
webReque st:https://www.google.com/gen_204?v = 3& s = web& atyp = ci; 152,ttlc.0,cbt.96&安培; PFM = N.1,ttfc.152,ttlc.0,cbt.96&安培; PMD = max.17,avg.2,0,1,0,1,0,1, 5,0,0,0,0,0,1,1,1,1,1,11,17,1&安培; IMN = 1&安培; ADH =安培; XJS = dispose.3.11.ifl.1.fpe.1。 jsa.1.m.0.lu.0& it = jradf.9& ima = 1& rt = ol.553,jsrt.155,prt.557,pprt.557,iml.558,aft.557
webRequest:https://www.google.com/xjs/_/js/k=xjs.s.en_US.tUVHO5ck74k.O/m=aspn,crd,sy7,sy268,sy314,sy3,sy9,sy54,sy315 ,sy316,sy27,sy317,DVL,sy57,sy58,SY300,EM11,VS,sy85,sy86,sy88,sy90,sy81,sy83,sy87,sy91,sy78,sy84,sy89,sy92,sy79,TNV,sy46,ATN ,sy355,d31,sy93,sy168,sy169,rqa,me / am = AFCSBBCI-H8ICLcQLEgFGBgE / rt = j / d = 0 / t = zcms / rs = ACT90oG-vU2X0tyaGFDLQbRJNbKCWyOApg

tabs.updated event :tabId = 37 :: changeInfo keys:status :: changeInfo.status = undefined(override-> loading)
tab.status = complete(override-> loading)testTabEvents.js:96:9

我们bRequest:https://www.google.com/gen_204?atyp=i&ct=slh&cad=&ei=bqW2V8rcMMfkjwOEtKXACQ&s=3&v=2&pv=0.5883361922868646&me=4:1471589138584,e ,U& zx = 1471589798811
webRequest:https://www.google.com/gen_204?atyp=i&ct=slh&cad=&ei=pa22V6CHGoHAjAPhgoPQBg&t=W&s=1&v= 2& pv = 0.3475507940470587& me = 1:1471589797809,x:4053,e,B& zx = 1471589801864

上述事件信息是通过运行我在此答案中的扩展(针对webRequests)以及以下扩展:

testTabEvents.js
(手工修改,因为我把它放在这个答案,所以可能有一个或两个错误): p>

  chrome.tabs.onUpdated.addListener(function(tabId,changeInfo,tab){
let output =;
//我们使用tab而不是changeInfo的属性,因为在测试中它是
//清除changeInfo并不总是正确填充。密钥可能只是
//存在,但没有任何与之相关的值。

// *
//测试显示事件何时被触发的输出。
//通过实验确定哪些事件要被忽略,哪些
//组合和事件序列在页面导航过程中发生。

函数addPropToOutput(prop){
if(tab.hasOwnProperty(prop)){
output + =(changeInfo.hasOwnProperty(prop))? '\\\
tab。'+ prop +'='+ tab [prop]:'';
if(prop ==='status'){
output + =((changeInfo.hasOwnProperty(status)&&typeof changeInfo.status ==='undefined')?'(重载 - >载入)':'')
}
} else {
output + =(changeInfo.hasOwnProperty(prop))? '\\\
changeInfo。'+ prop +'='+ changeInfo [prop]:'';
}
}

//需要状态和URL总是
changePropertiesOrder.forEach(addPropToOutput);
Object.getOwnPropertyNames(changeInfo).forEach(function(prop){
if(changePropertiesOrder.indexOf(prop)=== -1){
//不在列表中
addPropToOutput(prop);
}
});
$ b console.log(tabs.updated event:tabId =+ tabId +:: changeInfo keys:
+ Object.keys(changeInfo)
+(changeInfo。 hasOwnProperty(status)?':: changeInfo.status ='+ changeInfo.status:'')
+((changeInfo.hasOwnProperty(status)& typeof changeInfo.status ===' undefined')?'(override-> loading)':'')
+ output
);
if(changeInfo.hasOwnProperty(status)&& typeof changeInfo.status ==='undefined'){
changeInfo.status ='loading';
}
});
$ b $ var webNavEvents = ['BeforeNavigate',
'已提交',
'已完成',
//'CreatedNavigationTarget',// Firefox不支持
'DOMContentLoaded',
'ErrorOccurred',
'HistoryStateUpdated',
'ReferenceFragmentUpdated'
//'TabReplaced'//不支持Firefox
];

webNavEvents.forEach(function(navType){
browser.webNavigation ['on'+ navType] .addListener(function(type,details){
console.log(' \twebNavigation->'+ type
+':tadId ='+ details.tabId
+':: url ='+ details.url
+((typeof details.transitionType = =='string')?':: transitionType ='+ details.transitionType:'')
$ b $;
} .bind(undefined,navType));
} );

manifest.json

  {
description:在页面加载时测试tabs.onUpdated和webNavigation事件,
manifest_version:2,
name:onUpdated and webNavigation event testing,
version:0.1,
applications:{
gecko:{
id
strict_min_version:45.0
}
},
权限:[
webNavigation,
onUpdatedWebNavigationEventTesting @

scripts:[testTabEvents.js]
}
},


I see this behavior only when google SERP page is loading (when searched from the search box on google.com/ or box on SERP page it self). I was seeing expected behavior for other pages i.e., I see undifined, loading and finally a complete.

chrome.tabs.onUpdated.addListener( function(tabId, changeInfo, tab){
console.log(changeInfo.status); // prints undefined couple of times and then completed (no sign of loading).
}

I'm working on extension that behaves differently depending on tabs status.

The same code works as expected in chrome.

Also refreshing the SERP page triggers loading and completed status as expected.

解决方案

Firefox and Google Chrome are different browsers. WebExtensions is very new for Firefox. Even when it is mature, Firefox and Google Chrome will be different. This may require you to have significantly different sections of code for the various browsers your extension is supposed to run on.

Currently in Firefox, the changeInfo object that is passed to the listener function for chrome.tabs.onUpdated can be invalid. It is supposed to have only two possible values: loading or complete.

It appears that there is a bug that makes it such that changeInfo can have the property status, but the value of that property is undefined. In these cases, the tabs.Tab object with is also passed to a tabs.onUpdated listener, has a property status with a value that is a string. In most cases, that value is 'completed', even when that does not appear to be accurate.

It looks like this may be able to be worked around relatively easily. It depends on what you need.

The following code will override the erroneous undefined values for changeInfo.status with the assumption that they are 'loading':

chrome.tabs.onUpdated.addListener(function(tabId, changeInfo, tab) {
    if(changeInfo.hasOwnProperty("status") && typeof changeInfo.status === 'undefined'){
        changeInfo.status = 'loading';
    }
});

The reality is that you will need to determine for yourself what works for your extension. Firefox and Chrome are going to give somewhat different information to your extension.

For the situation which you described (Google main page to SERP page) the combined webRequest, webNavigation, and tabs.onUpdated events give you the following information:

        webRequest: https://www.google.com/images/nav_logo242.png
        webRequest: https://www.google.com/complete/search?sclient=psy-ab&site=&source=hp&q=SERP&oq=&gs_l=&pbx=1&bav=on.2,or.&bvm=bv.129759880,d.cGc&fp=1&biw=1256&bih=924&dpr=1&pf=p&gs_rn=64&gs_ri=psy-ab&cp=4&gs_id=kv&xhr=t&tch=1&ech=1&psi=E6u2V_S8BY_gjwPakICACA.1471589139270.1
        webRequest: https://www.google.com/gen_204?atyp=i&ct=1&cad=1&rsm=6&ei=E6u2V_S8BY_gjwPakICACA&zx=1471589794481

tabs.updated event: tabId=37:: changeInfo keys:status ::changeInfo.status=undefined (override->loading)
tab.status=complete (override->loading)testTabEvents.js:96:9

tabs.updated event: tabId=37:: changeInfo keys:status,url ::changeInfo.status=complete
tab.status=complete
tab.url=https://www.google.com/?gws_rd=ssl#q=SERPtestTabEvents.js:96:9

        webRequest: https://www.google.com/search?sclient=psy-ab&site=&source=hp&q=SERP&oq=SERP&gs_l=hp.3..0i3k1j0l3.655013.655013.0.657681.1.1.0.0.0.0.173.173.0j1.1.0....0...1c.1.64.psy-ab..0.1.163.LqQ90ZRWj7o&pbx=1&bav=on.2,or.&bvm=bv.129759880,d.cGc&fp=1&biw=1256&bih=924&dpr=1&tch=1&ech=1&psi=E6u2V_S8BY_gjwPakICACA.1471589139270.3

    webNavigation->ReferenceFragmentUpdated: tadId=37:: url=https://www.google.com/?gws_rd=ssl#q=SERPtestTabEvents.js:182:13

tabs.updated event: tabId=37:: changeInfo keys:status ::changeInfo.status=undefined (override->loading)
tab.status=complete (override->loading)testTabEvents.js:96:9

tabs.updated event: tabId=37:: changeInfo keys:status ::changeInfo.status=undefined (override->loading)
tab.status=complete (override->loading)testTabEvents.js:96:9

        webRequest: 
        webRequest: https://id.google.com/verify/NQAAAB8aqx-h_1Es5zxXakqEQ4VnEYZCXpWW_8Rmrl4pN1yV-s-1d_qg6kBSbexs0XcddYBKPk8NAwLOwyJ-W75hWEw
        webRequest: https://www.google.com/gen_204?v=3&s=web&atyp=csi&ei=pa22V6CHGoHAjAPhgoPQBg&ei=pa22V6CHGoHAjAPhgoPQBg&cr=r&imp=0&pfa=n.1,ttfc.152,ttlc.0,cbt.96&pfm=n.1,ttfc.152,ttlc.0,cbt.96&pmd=max.17,avg.2,0,1,0,1,0,1,5,0,0,0,0,0,1,1,1,1,1,11,17,1&imn=1&adh=&xjs=dispose.3.11.ifl.1.fpe.1.jsa.1.m.0.lu.0&it=jradf.9&ima=1&rt=ol.553,jsrt.155,prt.557,pprt.557,iml.558,aft.557
        webRequest: https://www.google.com/xjs/_/js/k=xjs.s.en_US.tUVHO5ck74k.O/m=aspn,crd,sy7,sy268,sy314,sy3,sy9,sy54,sy315,sy316,sy27,sy317,dvl,sy57,sy58,sy300,em11,vs,sy85,sy86,sy88,sy90,sy81,sy83,sy87,sy91,sy78,sy84,sy89,sy92,sy79,tnv,sy46,atn,sy355,d3l,sy93,sy168,sy169,rqa,me/am=AFCSBBCI-H8ICLcQLEgFGBgE/rt=j/d=0/t=zcms/rs=ACT90oG-vU2X0tyaGFDLQbRJNbKCWyOApg

tabs.updated event: tabId=37:: changeInfo keys:status ::changeInfo.status=undefined (override->loading)
tab.status=complete (override->loading)testTabEvents.js:96:9

        webRequest: https://www.google.com/gen_204?atyp=i&ct=slh&cad=&ei=bqW2V8rcMMfkjwOEtKXACQ&s=3&v=2&pv=0.5883361922868646&me=4:1471589138584,e,U&zx=1471589798811
        webRequest: https://www.google.com/gen_204?atyp=i&ct=slh&cad=&ei=pa22V6CHGoHAjAPhgoPQBg&t=W&s=1&v=2&pv=0.3475507940470587&me=1:1471589797809,x:4053,e,B&zx=1471589801864

The above event information was obtained from running the extension I put in this answer (for the webRequests) along with the following extension:

testTabEvents.js (hand modified as I put it in this answer, so may have an error or two):

chrome.tabs.onUpdated.addListener(function(tabId, changeInfo, tab) {
    let output="";
    //We use the properties of "tab" instead of "changeInfo" because in testing it was
    //  clear that changeInfo was not always properly populated. The key(s) may just
    //  exist, but not have any value associated with them.

    //*
    //Testing output showing when the event is fired.
    //  This is used to determine, by experimentation, what events to ignore and which
    //  combinations and sequence of events occur during page navigation.

    function addPropToOutput(prop){
        if(tab.hasOwnProperty(prop)){
            output += (changeInfo.hasOwnProperty(prop)) ? '\ntab.' + prop + '=' + tab[prop] : '';
            if(prop === 'status'){
                output += ((changeInfo.hasOwnProperty("status") && typeof changeInfo.status === 'undefined') ? ' (override->loading)' :'')
            }
        }else{
            output += (changeInfo.hasOwnProperty(prop)) ? '\nchangeInfo.' + prop + '=' + changeInfo[prop] : '';
        }
    }

    //Want status and url always first
    changePropertiesOrder.forEach(addPropToOutput);
    Object.getOwnPropertyNames(changeInfo).forEach(function(prop){
        if(changePropertiesOrder.indexOf(prop) === -1){
            //Not in the list
            addPropToOutput(prop);
        }
    });

    console.log("tabs.updated event: tabId=" + tabId + ":: changeInfo keys:"
                + Object.keys(changeInfo)
                + (changeInfo.hasOwnProperty("status") ? ' ::changeInfo.status=' + changeInfo.status : '')
                + ((changeInfo.hasOwnProperty("status") && typeof changeInfo.status === 'undefined') ? ' (override->loading)' :'')
                + output
    );
    if(changeInfo.hasOwnProperty("status") && typeof changeInfo.status === 'undefined'){
        changeInfo.status = 'loading';
    }
});

var webNavEvents = ['BeforeNavigate',
                    'Committed',
                    'Completed',
                    //'CreatedNavigationTarget', //Not supported by Firefox
                    'DOMContentLoaded',
                    'ErrorOccurred',
                    'HistoryStateUpdated',
                    'ReferenceFragmentUpdated'
                    //'TabReplaced' //Not supported by Firefox
                    ];

webNavEvents.forEach(function(navType){
    browser.webNavigation['on' + navType].addListener(function(type,details){
        console.log('\twebNavigation->' + type 
                    + ': tadId=' + details.tabId
                    + ':: url=' + details.url
                    + ((typeof details.transitionType === 'string') ? ':: transitionType=' + details.transitionType : '')

        );
    }.bind(undefined,navType));
});

manifest.json:

{
    "description": "Test tabs.onUpdated and webNavigation events on page load",
    "manifest_version": 2,
    "name": "onUpdated and webNavigation event testing",
    "version": "0.1",
    "applications": {
        "gecko": {
            "id": "onUpdatedWebNavigationEventTesting@testing",
            "strict_min_version": "45.0"
        }
    },
    "permissions": [
        "webNavigation",
        "activeTab",
        "tabs"
    ],
    "background": {
        "scripts": ["testTabEvents.js"]
    }
}

这篇关于tabs.onUpdated.addListener的changeInfo.status从未定义到完成而不需要加载的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆