gpt4 book ai didi

javascript - 如何将 mixpanel 与 angular2 集成

转载 作者:数据小太阳 更新时间:2023-10-29 05:02:08 29 4
gpt4 key购买 nike

在 index.html 中,我添加了来自 https://mixpanel.com/help/reference/javascript 的混合面板代码.

在我的

export class MixpanelService {

constructor() {
mixpanel.init("sdfsdf", '', "development");
}

public track() {
mixpanel.track('click', {pageName:'login'})
}
}

出现以下错误:

Cannot find name 'mixpanel'.
mixpanel.init("sdfsdf", '', "development");

谁能帮我解决这个问题。

最佳答案

首先,为浏览器安装mixpanel。这很重要。

npm install --save mixpanel-browser

安装相应的类型:

npm install --save @types/mixpanel

并将您的跟踪脚本添加到 index.html 没有 mixpanel.init():

<!-- start Mixpanel -->
<script type="text/javascript">
(function(e,b){if(!b.__SV){var a,f,i,g;window.mixpanel=b;b._i=[];b.init=function(a,e,d){function f(b,h){var a=h.split(".");2==a.length&&(b=b[a[0]],h=a[1]);b[h]=function(){b.push([h].concat(Array.prototype.slice.call(arguments,0)))}}var c=b;"undefined"!==typeof d?c=b[d]=[]:d="mixpanel";c.people=c.people||[];c.toString=function(b){var a="mixpanel";"mixpanel"!==d&&(a+="."+d);b||(a+=" (stub)");return a};c.people.toString=function(){return c.toString(1)+".people (stub)"};i="disable time_event track track_pageview track_links track_forms register register_once alias unregister identify name_tag set_config people.set people.set_once people.increment people.append people.union people.track_charge people.clear_charges people.delete_user".split(" ");
for(g=0;g<i.length;g++)f(c,i[g]);b._i.push([a,e,d])};b.__SV=1.2;a=e.createElement("script");a.type="text/javascript";a.async=!0;a.src="undefined"!==typeof MIXPANEL_CUSTOM_LIB_URL?MIXPANEL_CUSTOM_LIB_URL:"file:"===e.location.protocol&&"//cdn.mxpnl.com/libs/mixpanel-2-latest.min.js".match(/^\/\//)?"https://cdn.mxpnl.com/libs/mixpanel-2-latest.min.js":"//cdn.mxpnl.com/libs/mixpanel-2-latest.min.js";f=e.getElementsByTagName("script")[0];f.parentNode.insertBefore(a,f)}})(document,window.mixpanel||[]);
</script>
<!-- end Mixpanel -->

我强烈建议创建您自己的服务,这可能非常简单:

import { Injectable } from '@angular/core';
import * as mixpanel from 'mixpanel-browser';

@Injectable({
providedIn: 'root'
})
export class MixpanelService {

/**
* Initialize mixpanel.
*
* @param {string} userToken
* @memberof MixpanelService
*/
init(userToken: string): void {
mixpanel.init('your-project-token');
mixpanel.identify(userToken);
}

/**
* Push new action to mixpanel.
*
* @param {string} id Name of the action to track.
* @param {*} [action={}] Actions object with custom properties.
* @memberof MixpanelService
*/
track(id: string, action: any = {}): void {
mixpanel.track(id, action);
}
}

请注意,我从我的 userAuthService 调用 init() 函数,但您可以做任何您想做的事。只需确保在开始跟踪之前调用了 init()

然后,在您的其余代码中,您可以使用:

constructor(private mixpanelService: MixpanelService) { }

someFunction() {
this.mixpanelService.track('Some action', {
customPropertyOne: 'customValueOne',
customPropertyTwo: 'customValueTwo'
});
}

关于javascript - 如何将 mixpanel 与 angular2 集成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40249426/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com