Mixpanel iOS Objective-C库技术文档
安装指南
通过CocoaPods安装
- 如果是第一次使用CocoaPods,请先执行
gem install cocoapods
安装CocoaPods。若已安装,请跳至第2步。 - 在Xcode项目目录下运行
pod setup
创建本地CocoaPods规范镜像。 - 在终端运行
pod init
生成Podfile,并在生成的Podfile中添加pod 'Mixpanel'
。 - 在Xcode项目目录下运行
pod install
。CocoaPods将下载并安装Mixpanel库,并创建一个新的Xcode工作空间。在Xcode中打开这个工作空间,或者在终端输入open *.xcworkspace
。
通过Carthage安装
Mixpanel支持使用Carthage将依赖项打包为框架。在Cartfile中包含以下依赖项:
github "mixpanel/mixpanel-iphone"
查阅Carthage文档了解更多信息。
通过Swift Package Manager安装
- 在Xcode中,选择文件 > 添加包...
- 输入此存储库的包URL,并选择版本大于或等于v4.0.0。
初始化项目
在AppDelegate.m中导入 #Import "Mixpanel/Mixpanel.h"
并在[application:didFinishLaunchingWithOptions:]方法中调用[sharedInstanceWithToken:],使用项目令牌作为参数。
#import "Mixpanel/Mixpanel.h"
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
...
[Mixpanel sharedInstanceWithToken:@"YOUR_API_TOKEN" trackAutomaticEvents:NO];
...
}
发送数据
初始化库后,Mixpanel将自动收集一些常见的移动事件。可以在项目设置中启用/禁用自动收集。此外,Mixpanel还会自动跟踪一些默认属性。了解更多默认属性。
Mixpanel *mixpanel = [Mixpanel sharedInstance];
[mixpanel track:@"Sign Up" properties:@{
@"source": @"Pat's affiliate site",
@"Opted out of email": @YES
}];
检查发送成功
在Mixpanel中打开“事件”查看传入的事件。
一旦数据到达我们的API,通常需要约60秒才能处理、存储并在项目中查询。
完整代码示例
以下是一个涵盖快速入门指南中所有内容的可运行代码示例。
#import "Mixpanel/Mixpanel.h"
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
...
Mixpanel *mixpanel = [Mixpanel sharedInstanceWithToken:@"YOUR_API_TOKEN" trackAutomaticEvents:NO];
[mixpanel track:@"Sign Up" properties:@{
@"source": @"Pat's affiliate site",
@"Opted out of email": @YES
}];
...
}
常见问题
我想停止跟踪Mixpanel中的某个事件/事件属性,这可能吗?
是的,在Lexicon中,您可以拦截并丢弃传入的事件或属性。Mixpanel不会存储您选择丢弃的任何新事件或属性数据。查看这篇文章了解更多信息。
我有一个测试用户我想将其排除在跟踪之外,我该如何操作?
Mixpanel的客户端跟踪库包含一个optOutTracking()方法,它将用户的本地退出跟踪状态设置为“true”,并阻止从用户设备发送数据。在退出跟踪用户部分可以找到更详细的说明。
为什么我的事件没有显示出来?
为了保护电池寿命和客户带宽,Mixpanel库不会立即发送您记录的事件。相反,它会每60秒将事件批次发送到Mixpanel服务器,同时您的应用程序正在运行,以及当应用程序过渡到后台时。如果您想在特定时刻强制刷新,可以调用flush()。
[mixpanel flush];
如果60秒后事件仍未显示,请检查是否已经退出了跟踪。您还可以启用Mixpanel调试和日志记录,它允许您查看来自Mixpanel库的调试输出。要启用它,请将enableLogging设置为true。
mixpanel.enableLogging = YES;
从iOS 14.5开始,我需要通过AppTrackingTransparency框架请求用户权限才能使用Mixpanel吗?
不需要,Mixpanel不使用IDFA,因此不需要通过AppTrackingTransparency(ATT)框架请求用户权限。
如果使用Mixpanel,如何回答App Store的隐私问题?
请参考我们的Apple App Developer Privacy Guidance
想了解更多!
不用担心,以下是一些您会发现有用的链接:
有任何问题?请联系Mixpanel 支持,快速与聪明人交流。
- 国产编程语言蓝皮书《国产编程语言蓝皮书》-编委会工作区017
- nuttxApache NuttX is a mature, real-time embedded operating system (RTOS).C00
- qwerty-learner为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workersTSX027
- 每日精选项目🔥🔥 01.17日推荐:一个开源电子商务平台,模块化和 API 优先🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~026
- Cangjie-Examples本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie045
- 毕方Talon工具本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python039
- PDFMathTranslatePDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython05
- mybatis-plusmybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.comJava03
- advanced-javaAdvanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。JavaScript0108
- taro开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/TypeScript09