我想在不使用react-ga包的情况下将google分析集成到我的react应用程序中。具体地说,我希望能够访问react组件中的ga函数。如果我将analytics.js脚本导入到我的html中,我如何访问ga函数?当我尝试console.log(window.ga)时,我被告知它是未定义的。谢谢!
class App extends React.Component {
render() {
console.log(window.ga);
return (
<h1>This is a react app!</h1>
);
}
}
ReactDOM.render(<App />, document.getElementById('app'));<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<script async src='//www.google-analytics.com/analytics.js'></script>
<div id="app"></div>
发布于 2018-11-27 11:37:48
这是您应该包含的代码片段:
(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','https://www.google-analytics.com/analytics.js','ga');如果您想保留与analytics.js的链接,请执行此操作
window.ga=window.ga||function(){(ga.q=ga.q||[]).push(arguments)};ga.l=+new Date;发布于 2019-02-22 01:59:08
我建议使用细分分析库并遵循我们的React quickstart guide。您可以使用单个react-router在React组件中跟踪页面访问和用户行为。下面是使用React事件处理程序跟踪User Signup点击的示例:
export default class SignupButton extends Component {
trackEvent() {
window.analytics.track('User Signup');
}
render() {
return (
<button onClick={this.trackEvent}>
Signup with Segment today!
</button>
);
}
}我是https://github.com/segmentio/analytics-react的维护者。有了Segment,如果你有兴趣尝试多种分析工具(我们支持250+目的地),你可以通过开关开关来切换不同的目的地,而不需要编写任何额外的代码。
https://stackoverflow.com/questions/53489550
复制相似问题