2015-10-20 32 views
0

I'm面臨着由comScore的給出以下JS方法問題:Comscore的調查問題中的Android

function ns_onclick(q, f, u, b, o) { 
var i = window, 
    l = i.ns_p, 
    m = l && l.src, 
    s = "&ns_", 
    h = document.referrer.replace(/\/$/, ""), 
    f = f || q.href, 
    o = o || "", 
    j = { 
     t: 0, 
     o: 0 
    }, 
    e = eventURL = c1_match = c2_match = "", 
    c = /\bc1=[^&]+\b/i, 
    g = /\bc2=[^&]+\b/i, 
    p = (i.encodeURIComponent ? encodeURIComponent : escape), 
    n = "1.11111.11"; 


if (m && (c1_match = l.src.match(c)) && !c.test(u)) { 
    e += "&" + c1_match 
} 
if (m && (c2_match = l.src.match(g)) && !g.test(u)) { 
    e += "&" + c2_match 
} 
if (m) { 
    var t = l.src, 
     k = t.indexOf("?"); 
    eventURL = t.substr(0, k > -1 ? k : t.length) + "?" 
} 
eventURL = [eventURL, u, e, s, "type=", b, s, "action=view", s, "_t=", +new Date, h ? s + "referrer=" + p(h) : "", s, "sc_sv=", n, s, "sc_href=", p(f).substr(0, 1000)].join(""); 

var r = q && q.target ? q.target.replace(/^_/, "") : "self", 
    d = new Image(); 

if (i[r]) { 
    j.t = (function(w, v, a) { 
     return function() { 
      clearTimeout(a.o); 
      d.onload = d.onerror = function() { 
       return 
      }; 
      i[w].location.href = v 
     } 
    })(r, f, j); 
    j.o = setTimeout(j.t, 5000); 
    d.onload = d.onerror = j.t 
} else { 
    i.open(f, r, o); 
} 
d.src = eventURL; 
return false}; 

我打電話的方式,方法,因爲它遵循:

<button onclick="ns_onclick(this, '', 'osp_ev=event', 'clickin');" nav-transition="none" ng-show="backButtonHiden" class="button button-icon button-clear ion-navicon-round" menu-toggle="sideMenuToggle(false)" data-tap-disabled="true"></button> 

的方法是完美地稱呼,似乎沒有任何問題一路走過。但不知何故,它使我的應用程序與在屏幕上顯示的folling錯誤崩潰:

enter image description here

我擔心最多的就是這個工作完全在iOS。它似乎像Android試圖打開文件,顯然不存在......任何想法?

編輯:我發現了問題所在,在以下行:

i[w].location.href = v 

v是「不確定」,它使應用程序崩潰!你可以看到...在ns_onclick函數上的代碼是一團糟,而JS並不是我的領域。有沒有人在混合應用程序中使用Comscore分析?如果是這樣,在網站或應用程序上使用它有什麼區別?

回答

2

我終於明白了!問題不在Comscore提供的JS代碼上,它位於HTML標籤上。這是我在做什麼:

<button onclick="ns_onclick(this, '', 'osp_ev=event', 'clickin');" nav-transition="none" ng-show="backButtonHiden" class="button button-icon button-clear ion-navicon-round" menu-toggle="sideMenuToggle(false)" data-tap-disabled="true"></button> 

,這是它應該怎麼做:

<a href="#/path" onclick="ns_onclick(this, '', 'osp_ev=event', 'clickin');" nav-transition="none" ng-show="backButtonHiden" class="button button-icon button-clear ion-navicon-round" menu-toggle="sideMenuToggle(false)" data-tap-disabled="true"></a> 

正如你可以看到,從來就由<改變<按鈕>標籤一個>標記,並將其添加到它的屬性。必須將href設置爲html標籤,並且這隻能通過鏈接標籤完成。我嘗試添加href到按鈕,只是爲了嘗試,但它不工作...我不知道這是因爲它只適用於< a>或任何其他原因...正如我在這個問題上所說的那樣,這其實並不是我的領域。

我希望它能幫助你解決同樣的問題。