1、先决条件:使用新版本的JavaScript跟踪代码
2、JavaScript跟踪代码的功能
(1)自定义在Piwik中显示的页面名称
(2)手动触发目标转化
(3)考虑一个主机的“别名”,不将这个域名的链接记录为“出站链接”
(4)禁用下载及出站链接跟踪
(5)禁用特定CSS类的下载及出站链接跟踪
(6)禁用特定链接上的下载及出站链接跟踪
(7)将一个链接的点击在Piwik中强制记录为下载
(8)将一个链接的点击在Piwik中强制记录出站链接
(9)修改暂停定时器
(10)修改跟踪为“下载”的文件扩展名列表
3、其他函数
(1)自定义发送到Piwik.php跟踪脚本的JASON数据
(2)多个Piwik跟踪代码
(3)异步跟踪
(4)覆盖Piwik.js的单元测试
4、跟踪API可用的所有方法列表
5、相关文档
Piwik配备了相当强大的JavaScript跟踪API。高级用户能使用Piwik跟踪代码定制一些网站分析数据记录在Piwik中的方式。插件开发者也能向Piwik跟踪脚本发送定制化的JSON数据,并且在插件中使用这些数据。
1、先决条件:使用新版本的JavaScript跟踪代码
基本的Piwik跟踪代码如下:

<!– Piwik –>
 <script type=”text/javascript”>
 var pkBaseURL = ((“https:” == document.location.protocol) ? “https://{$PIWIK_URL}” : “http://{$PIWIK_URL}”);
 document.write(unescape(“%3Cscript src=’” + pkBaseURL + “piwik.js’ type=’text/javascript’%3E%3C/script%3E”));
 </script><script type=”text/javascript”>
 try {
 var piwikTracker = Piwik.getTracker(pkBaseURL + “piwik.php”, {$IDSITE});
 piwikTracker.trackPageView();
 piwikTracker.enableLinkTracking();
 } catch( err ) {}
 </script>
 <!– End Piwik Tag –>

在Piwik跟踪代码中,{$PIWIK_URL}将被替换为你的Piwik URL,{$IDSITE}将被替换为你在Piwik中跟踪的网站ID。
如果你的Piwik跟踪代码不是这样的,那么,你可能正在使用过时的旧版本。旧版本仍将按期望工作,继续跟踪你的访问者。但是,为了使用这个页面中所介绍的所有功能,你将需要使用新版本的跟踪代码。请访问你的Piwik管理部分,请求给定网站的JavaScript代码,并且将你的页面更新为新的代码。
2、JavaScript跟踪代码的功能
(1)定制Piwik中显示的页面名称
默认情况下,Piwik在Piwik界面中使用当前页面的URL作为页面的名称。如果您的URL很复杂,或者如果你想要定制Piwik跟踪页面的方式,你能在JavaScript标签中指定页面名称。

常用的方法是使用HTML标题的值:

[...]
piwikTracker.setDocumentTitle(document.title);
piwikTracker.trackPageView();


[...]
高级用户也能动态产生页面名称,例如在PHP中:

[...]
piwikTracker.setDocumentTitle("<?php echo $myPageTitle; ?>");
piwikTracker.trackPageView();


[...]
(2)手动触发目标转化

默认情况下,目标在Piwik被定义为部分URL的“匹配”(开始、包含或正则式匹配)。你也能默认将特定页面查看、下载或出站链接跟踪为目标。

在一些情况下,你想要将其他类型的动作登记为转化,例如:

•访问者提交一个表单:

•访问者在页面上停留超过给定时间

•访问者与你的Flash应用程序进行了一些交互

•用户提交了购物车并完成了支付:你能将Piwik跟踪代码提供给支付网站,这个网站将在稍后在你的Piwik数据库中登记这个转化以及自定义的收入。

•等等

使用Piwik JavaScript跟踪手动触发一个目标,你可以简单的这样做:

[...]
piwikTracker.trackGoal(1); // 记录目标1的一次转化


[...]
你也能为这个目标记录自定义收入,例如,你可以生成对跟踪目标的动态调用,以便设置这笔交易的收入:

[...]
piwikTracker.trackGoal(1, <?php echo $cart->getCartValue(); ?>); // 记录设置了自定义收入的目标1的一次转化


[...]
目标跟踪的更多信息见跟踪目标文档。

(3)考虑一个主机的“别名”,不将这个域名的链接记录为“出站链接”

默认情况下,所有域名不是当前域名的连接都被认为是出站链接。如果你有多个域名,不希望将指向这些网站的链接被认为是“出站链接”,那么你可以在一个域名数组中指定。如果你想要忽略特定域的二级域的所有点击,那么可以使用通配符。

[...]
piwikTracker.setDomains(["*.hostname1.com", "hostname2.com"]); // 至少目前跟踪的网站应添加到这个数组中
 piwikTracker.trackPageView();
[...]

(4)禁用下载及出站链接跟踪

Piwik跟踪代码默认启用点击和下载跟踪。禁用所有自动下载和出站链接跟踪,你必须去掉对enableLinkTracking()函数的调用:

[...]
// 我们注释掉启用链接跟踪的函数
 // piwikTracker.enableLinkTracking();
piwikTracker.trackPageView();
 [...]

(5)禁用特定CSS类的下载及出站链接跟踪

你能禁用对特定CSS类的下载及出站链接的自动跟踪

[...]
piwikTracker.setIgnoreClasses( "no-tracking" ); // 你也能传递一个字符串数组
piwikTracker.trackPageView();
 [...]

这将导致链接<a href=’http://example.com’ class=’no-tracking’>Test</a>的点击不被计算。

(6)禁用特定链接的下载或出站链接的跟踪

如果你想要一直忽略特定链接的下载或出站链接跟踪,你能为它添加“piwik_ignore”CSS类:

<a href=’latest.zip’class=’piwik_ignore’>不想跟踪为下载的文件</a>

(7)将一个链接的点击在Piwik中强制记录为下载

如果你想让Piwik将一个给定链接考虑为下载,那么,你可以为这个链接添加“piwik_download”CSS类:

<a href='last.php'class='piwik_download'>我想要跟踪为下载的链接</a>

注:你可以自定义和重命名用于强制被记录为下载的点击的CSS类:

[...]
// 现在所有“download”CSS类的链接将为记录为下载
 piwikTracker.setDownloadClasses( "download" ); //你也可以传递一个字符串数组
piwikTracker.trackPageView();
 [...]

(8)将一个链接的点击在Piwik中强制记录出站链接

如果你想让Piwik将一个给定的链接考虑为出站链接(指向当前域或一个别名域的链接),那么,你可以为这个链接添加“piwik_link”CSS类:

<a href='http://mysite.com/partner/'class='piwik_link'>我想要跟踪为出站链接的链接</a>

注:你可以自定义和重命名用于强制被记录为出站链接的点击的CSS类:

[...]
//现在所有“external”CSS类的链接上的点击将被计算为出站链接
 piwikTracker.setLinkClasses( "external" ); //你也可以传递一个字符串数组
piwikTracker.trackPageView();
 [...]

(9)修改暂停定时器

当访问者点击文件下载,或点击出站链接时,Piwik将记录它。为了这样做,Piwik在重定向用户到请求的文件或链接之前添加了一小段延迟。我们使用的默认值是500ms,但是你可以将它设置为更短的时间。但是,需要注意的是,这样做会带来由于这段时间过短而使Piwik无法记录数据的风险。

[...]
piwikTracker.setLinkTrackingTimer( 250 ); // 250 毫秒
piwikTracker.trackPageView();
 [...]

(10)修改跟踪为“下载”的文件扩展名列表

默认情况下,任何以下列这些文件扩展名之一结尾的文件在Piwik界面中都会被认为是“下载”:

7z|aac|arc|arj|asf|asx|avi|bin|csv|doc|exe|flv|gif|gz|gzip|hqx|jar|jpe?g|js|mp(2|3|4|e?g)|mov(ie)?|msi|msp|pdf|phps|png|ppt|qtm?|ra(m|r)?|sea|sit|tar|tgz|torrent|txt|wav|wma|wmv|wpd||xls|xml|z|zip

为了替换你想要跟踪为文件下载的扩展名列表,你可以:

[...]
piwikTracker.setDownloadExtensions( "jpg|png|gif" ); //我们现在只跟踪图片上的点击
piwikTracker.trackPageView();
 [...]

如果你想跟踪新的文件名类型,你可以仅将它添加到这个列表中:

[...]
//点击以mp5或mp6结尾的URL将被计算为下载
 piwikTracker.addDownloadExtensions( "mp5|mp6" );
piwikTracker.trackPageView();
 [...]

3、其他函数

(1)向piwik.php跟踪脚本发送自定义JSON数据(插件开发者)

例如,向一个(虚构的)跟踪插件发送用户ID数据:

[...]
var user = { 'userId' : user_id };
 piwikTracker.setCustomData( user );
piwikTracker.trackPageView();
 [...]

在trackLink方法中,你也可以为特定点击发送自定义数据。例如,发送交易数据供虚构的电子商务跟踪插件使用。

[...]
var trans = { 'orderId' : order_id,
 'storeId' : store_id,
 'total' : total,
 'city' : city,
 'state' : state,
 'country' : country,
 'skus' : 'A;B;C',
 'units' : '1;2;1'
};
 piwikTracker.trackLink( '/store', 'addTransaction', trans );
 [...]

所有的自定义数据能被设置为JASON对象。Piwik代码将自动编码JASON对象并且构建为一个字符串版本,随后你可以在php段使用json_decode()解码。我们使用json.org上的开源JSON工具。

注:目前,自定义数据不会记录在Piwik数据库中。插件使用的自定义数据必须在自己的表中存储数据,然后进行归档。如果你需要别人帮忙构建这样的功能,请在piwik-hacker的邮箱列表中询问你的问题(更多信息)。

(2)多个Piwik跟踪器

可以使用指向相同或不同Piwik服务器的多个Piwik跟踪器跟踪同一个页面。为了减少加载时间,你可以加载piwik.js一次。每一次调用Piwik.getTracker()都返回惟一Piwik跟踪器对象(事例),这些跟踪对象可以进行配置。

调用getTracker的第一个参数

<script type="text/javascript">
 try {
 var piwikTracker = Piwik.getTracker("http://URL_1/piwik.php", 1);
 piwikTracker.trackPageView();
 var piwik2 = Piwik.getTracker("http://URL_2/piwik.php", 4);
 piwik2.trackPageView();
 } catch( err ) {}
 </script>

注意你也可以手动设置网站ID和piwik跟踪器URL,而不是在getTracker调用中设置它们:

//我们替换Piwik.getTracker("http://example.com/piwik/", 12)
 var piwikTracker = Piwik.getTracker();
 piwikTracker.setSiteId( 12 );
 piwikTracker.setTrackerUrl( "http://example.com/piwik/" );
 piwikTracker.trackPageView();

(3)异步跟踪

Piwik JavaScript跟踪API也支持异步跟踪,以便页面加载(或看起来加载)的更快。配置和跟踪调用被推送到_paq数组进行执行,与piwik.js加载异步。其形式为:

_paq.push([ 'API_method_name', parameter_list ]);

异步Piwik跟踪代码应插入到<head>标签中,形式如下:

<!-- Piwik -->
 <script type="text/javascript">
 var _paq = _paq || [];
 (function(){
 var u=(("https:" == document.location.protocol) ? "https://{$PIWIK_URL}" : "http://{$PIWIK_URL}");
 _paq.push(['setSiteId', {$IDSITE}]);
 _paq.push(['setTrackerUrl', u+'piwik.php']);
 _paq.push(['trackPageView']);
 var d=document,
 g=d.createElement('script'),
 s=d.getElementsByTagName('script')[0];
 g.type='text/javascript';
 g.defer=true;
 g.async=true;
 g.src=u+'piwik.js';
 s.parentNode.insertBefore(g,s);
 })();
 </script>
 <!-- End Piwik Tag -->

(为了清晰,以上代码段没有压缩。)

(4)覆盖Piwik.js的单元测试

Piwik JavaScript跟踪API由广泛JavaScript单元测试控件来确保代码的质量尽可能高,我们永远不会破坏这种功能。测试使用QUnit-jQuery单元测试执行器写的。运行这些测试,只需要检查Piwik的SVN端口汇合,进入/path/to/piwik/tests/javascript/。测试在你的浏览器中进行。

Piwik JavaScript API经过许多web浏览器的测试:包括(但不限于)火狐2、3.0、3.1;IE 5.5、6、7、8;Opera 7.54、8.54、9.64、10;Safari 3.0、3.2、4.0;Konqueror 3.5;SeaMonkey 1.1、2.0。我们有时使用browsershots.org来帮助测试。

(5)压缩piwik.js

Piwik.js被压缩为你的网站访问者将要下载的最小尺寸。我们使用YUI压缩器在压缩JavaScript(了解更多)。你可以在/js/piwik.js找到原始的未经压缩的版本。

4、跟踪API可用的所有方法列表

从Piwik类请求跟踪器实例

•Piwik.getTracker( trackerUrl, siteId )——获得跟踪器的新实例

•[Google Analytics等价物] _getTracker(account)

•[Yahoo! Analytics等价物] getTracker(account)

使用跟踪器对象

•enableLinkTracking()——在所有可以应用的链接元素上安装链接跟踪

•addListener(element)——为特定链接元素添加链接监听器。当点击时,Piwik将自动记录点击。

•setRequestMethod(method)——将请求方法设置为“GET”或“POST”(默认是“GET”)。使用POST请求方法,Piwik的主机必须与跟踪网站的主机相同(Piwik安装在与跟踪网站相同的域上)。

•trackGoal( idGoal, [customRevenue], [customData])——手动记录idGoal目标的一个转化,如果指定了的话,传递customRevenue和customData

•trackLink( url, linkType, [customData] )——手动记录来自你自己代码的一次点击。url是点击的URL。linkType可以是“link”出站链接也可以是“download”下载。

•trackPageView([customTitle], [customData])——记录这个页面的访问

•[Google Analytics等价物] _trackPageview(opt_pageURL)

•[Yahoo! Analytics等价物] submit()

跟踪器对象的设置

•setDocumentTitle( string )——重写文档标题

•[Yahoo! Analytics 等价物] YWATracker.setDocumentName(“xxx”)

•setDomains( array)——设置当做本地处理的主机名或域名数组

•[Google Analytics 等价物] _setDomainName(“.example.com”)

•[Yahoo! Analytics equivalent] setDomains(“*.abc.net”)

•setCustomData( object|string )——向服务器传递自定义数据

•setCustomUrl( string )——重写页面报告的URL

•setReferrerUrl( string )——重写检测到的Http-Referer

•setSiteId( integer )——指定网站的ID。多余的:能在getTracker()构造函数中指定。

•setTrackerUrl( string )——指定Piwik服务器URL。多余的:能在getTracker()构造函数中指定。

•setDownloadClasses( string | array )——设置处理为下载(除了piwik_download以外)的类。

•setDownloadExtensions( string )——设置识别为下载的文件扩展名列表。例如:“doc|pdf|txt”。

•addDownloadExtensions( string )——指定更多的识别为下载的文件扩展名。;例如:“doc|pdf|txt”。

•setIgnoreClasses( string | array )——设置如果出现在链接中将被忽略的类(除了piwik_ignore以外)

•setLinkClasses( string | array )——设置被处理为出站链接的类(除了piwik_link以外)

•setLinkTrackingTimer( integer )——设置链接跟踪的延迟,以毫秒为单位。