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 支持,快速与聪明人交流。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0151- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0111