Android中的Comscore问题

时间:2015-10-20 12:49:22

标签: javascript android comscore

我遇到了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>

该方法被称为完美,它似乎一直没有任何问题。但不知何故,它使我的应用程序崩溃,并在屏幕上显示了下拉错误:

enter image description here

最让我担心的是,这在iOS上完美运行。看起来Android正试图打开文件,显然不存在......有什么想法吗?

编辑:我发现问题出在以下一行:

i[w].location.href = v

v是“未定义”,它会让应用程序崩溃!正如您所看到的那样...... ns_onclick 函数上的代码是一团糟,JS并不是我的字段。有没有人曾在混合应用程序中使用Comscore分析?如果是这样,在网站或应用程序上使用它有什么区别吗?

1 个答案:

答案 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; 或任何其他原因......正如我在问题上所说,这实际上不是我的领域。

我希望如果你遇到同样的问题会有所帮助。