我遇到了comscore给出的以下JS方法的问题:
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>
该方法被称为完美,它似乎一直没有任何问题。但不知何故,它使我的应用程序崩溃,并在屏幕上显示了下拉错误:
最让我担心的是,这在iOS上完美运行。看起来Android正试图打开文件,显然不存在......有什么想法吗?
编辑:我发现问题出在以下一行:
i[w].location.href = v
v是“未定义”,它会让应用程序崩溃!正如您所看到的那样...... ns_onclick 函数上的代码是一团糟,JS并不是我的字段。有没有人曾在混合应用程序中使用Comscore分析?如果是这样,在网站或应用程序上使用它有什么区别吗?
答案 0 :(得分: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>
你可以注意到,我已经改变了&lt; &lt;按钮&gt; 标记a&gt; 标记,并将 href 属性添加到其中。必须将 href 设置为 html 标记,这只能通过链接标记完成。我试着将href添加到按钮,只是试一试,但它不起作用......我不知道这是因为它只适用于&lt; a&gt; 或任何其他原因......正如我在问题上所说,这实际上不是我的领域。
我希望如果你遇到同样的问题会有所帮助。