从跟踪代码中删除管道字符?

时间:2014-12-01 19:48:49

标签: javascript google-analytics

我有一个旧的项目是在日子里写的,并使用管道符( | )作为某些数据之间的分隔符。

Google分析跟踪代码包含管道符:

<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');

ga('create', '', 'auto');
ga('send', 'pageview');

</script>

当我将跟踪代码提供给项目时,由于使用了管道字符,它会出错。

是否可以从跟踪代码中删除/替换2管道字符,但保持跟踪代码功能正常?

这样可以省去我在旧代码中的大量黑客攻击; - )

1 个答案:

答案 0 :(得分:1)

修复绊倒|个字符的代码会更好,更多。

一个糟糕但有效的替代方法是将代码放在一个字符串中,但将每个|替换为等效的unicode转义序列,即\u007C

// EXPLANATORY COMMENT GOES HERE
var scriptEncoded =
"(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]\u007C\u007Cfunction(){ \
(i[r].q=i[r].q\u007C\u007C[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), \
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) \
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');";

eval(scriptEncoded);

ga('create', '', 'auto');
ga('send', 'pageview');

如果不清楚,这是有效的,因为在JavaScript中,与许多语言一样,you can use a Unicode escape sequence可以替代任何字符。例如,console.log("\u0066\u006F\u006F")会将foo打印到控制台,因为它们是fo的转义序列。

请注意:

  1. 字符串中的每一行都以\结尾,这对于字符串中的换行符是必需的。 (你也可以拿出换行符,但我认为这不太可读。)
  2. 真的需要在脚本顶部发表评论,解释为什么会这样,因为它是一个kludge而下一个看你代码的人会看到eval并且正确想知道WTF还在继续。