帮助文档
  • What's new
  • 增长平台全景图
  • 文档使用指南
  • 产品简介
    • 产品概述
    • 数据模型
      • 用户模型
        • 访问用户
        • 登录用户
        • 用户属性
      • 事件模型
        • 什么是事件
        • 无埋点事件
          • 概述
          • 访问事件及变量
          • 页面事件及变量
          • 元素事件及变量
        • 埋点事件
      • 统计模型
        • 指标-事件的度量
        • 维度-事件的属性
        • 预定义指标
        • 预定义维度
    • 数据定义
      • 用户变量
        • 登录用户变量
        • 访问用户变量
      • 页面级变量
      • 埋点事件及变量
        • 埋点事件和事件级变量
        • 转化变量
    • 数据安全
  • 开发者文档
    • SDK 集成
      • SDK 简介
      • 合规指南
        • Android SDK合规说明
        • iOS SDK合规说明
        • HarmonyOS SDK合规说明
        • Web JS SDK 合规说明
        • 小程序 SDK 合规说明
      • SDK 使用流程
      • Web JS SDK
        • Web JS SDK 更新日志
        • 概述
        • 集成最新SDK
        • SDK 版本1.x升级2.x指导
        • Web JS SDK API
          • API 2.x
        • Web半自动采集浏览事件
        • 常见问题
          • 为什么网站要允许iframe加载?
          • 为什么网站不能复写 window 对象?
          • 页面内部嵌入的 iframe 元素如何加载 SDK?
          • 同时集成了web sdk 和 hybrid sdk 会怎么处理?
          • 同时集成了web sdk 1.x 和web sdk 2.x会怎么处理?
          • 元素没有元素浏览量怎么处理?
          • display:none 的元素,其子元素中的a/button只采集一次浏览量,想每次曝光都采集怎么处理?
          • 设置了 growing-ignore 之后,其子元素也不采集怎么处理?
      • 原生 Android SDK
        • Android SDK更新日志
        • 无埋点 SDK 集成
        • 埋点 SDK 集成
        • Android SDK API
          • Gradle配置API
          • 初始化配置项API
          • 运行时API
          • 自定义数据上传API
        • Android半自动采集浏览事件
        • 1.x Android SDK 升级指导
        • 常见问题
          • 无埋点数据采集问题
          • 无埋点SDK中埋点API使用问题
          • SDK性能问题
          • 圈选问题
          • Gradle 常见问题
          • App内嵌H5页面常见问题
      • 原生 iOS SDK
        • iOS SDK 更新日志
        • 无埋点 SDK集成
        • 埋点 SDK集成
        • iOS SDK API
          • 初始化配置项API
          • 埋点SDK支持的其他接口
          • 动态添加属性说明
          • 自定义数据上传API
        • iOS半自动采集浏览事件
        • iOS SDK升级指导
        • 常见问题
        • 用户运营iOS SDK地址
      • 移动端第三方框架 SDK
        • React Native无埋点SDK
        • React Native埋点SDK
        • Flutter埋点SDK
        • Cordova埋点SDK
        • Weex埋点SDK
        • API Cloud埋点SDK
        • AppCan埋点SDK
        • uniapp 埋点SDK
        • Unity 埋点 SDK
        • 鸿蒙原生埋点 SDK
      • 小程序 SDK
        • 3.7及以下
          • 更新日志
          • 集成
            • 微信小程序
            • 支付宝小程序
            • 百度小程序
            • QQ小程序
            • 字节跳动小程序
            • 快应用
          • 数据采集API
          • 无埋点采集逻辑和高级配置
        • 3.8
          • 更新日志
          • 集成
            • 微信小程序
            • 阿里(支付宝)小程序
            • 百度小程序
            • 字节(抖音头条)小程序
            • QQ小程序
            • 快应用
          • 初始化配置
          • 数据采集API
          • 无埋点采集逻辑和高级配置
          • 旧版本与3.8对比
          • 旧版本升级到3.8
      • Hybrid JS SDK
      • 小程序和微信公众号H5 内嵌页 SDK
        • 更新日志
      • 微信小游戏 SDK
        • 更新日志
      • 服务端埋点SDK
        • Java埋点SDK
        • PHP埋点SDK
        • 常见问题
      • 仅集成埋点SDK的Hybrid JS SDK
    • SDK调试
      • 概述
      • Web Debugger
      • Mobile Debugger
      • 小程序&内嵌页Debugger
      • 验证埋点事件
        • 概述
        • 对 cstm(事件以及关联的事件级变量)上报进行验证
        • 对 pvar(页面级变量)进行验证
        • 对 evar(转化变量)进行验证
        • 对 ppl(用户变量)上报验证
    • API参考
      • 公共请求参数
      • 原始数据导出API V2
        • 概述
        • 事件表字段说明
          • 事件表关联
          • 无埋点事件字段
          • 埋点事件与变量字段
          • 广告相关字段
        • 接口定义
          • 获取不同类型原始数据下载链接
          • 获取全部事件类型原始数据的下载链接
        • 升级说明
        • 导出数据处理建议
      • 原始数据导出API V1
        • 概述
        • 字段说明
          • 事件类型
          • 无埋点事件字段
          • 埋点事件与变量字段
          • 广告相关字段
        • 接口定义
          • 获取原始数据下载链接
          • 来源管理数据导出 -- [接口下线 2020.11.02]
        • 导出数据处理建议
      • 统计数据导出API V3
        • V3接口概述
        • 接口定义
          • 获取事件分析数据
          • 获取漏斗分析数据
          • 获取留存分析数据
          • 获取分布分析数据
          • 获取用户分群的下载链接
          • 获取用户标签的下载链接
      • 统计数据导出API
        • 概述
        • 接口定义
          • 获取看板列表
          • 获取看板中的图表信息
          • 获取事件分析数据
          • 获取漏斗分析数据
          • 获取留存分析数据
          • 获取分群列表
          • 获取特定分群的用户列表
          • 获取圈选元素定义
      • 用户分群更新API
      • 广告监测链接创建API
        • 概述
        • 接口定义
          • 查询应用ID
          • 新建推广活动
          • 查询推广活动ID
          • 新建推广渠道
          • 查询推广渠道ID
          • 新建监测链接(吸引用户直接打开App)
          • 查询监测链接(吸引用户直接打开App)
          • 新建监测链接(增加APP下载量-同时推广iOS和Android)
          • 查询监测链接(增加APP下载量-同时推广iOS和Android)
          • 新建监测链接(增加App下载量-推广iOS或Android单个平台)
          • 查询监测链接(增加App下载量-推广iOS或Android单个平台)
          • 新建监测链接(推广网页)
          • 查询监测链接(推广网页)
          • 新建监测链接(微信小程序)
          • 查询监测链接(微信小程序)
      • 埋点数据上传API
      • 登录用户变量上传API
        • 登录用户变量上传
        • 维度分类上传
        • 既有登录用户ID上传
        • (旧)接口定义
          • 用户变量上传
          • 维度分类上传
      • 项目管理API
        • 概述
        • 从项目内移除成员
        • 获取埋点事件列表
        • 创建埋点事件
        • 更新埋点事件
        • 删除埋点事件
        • 获取事件级变量
        • 创建事件级变量
        • 获取页面级变量
        • 创建页面级变量
        • 获取登录用户变量
        • 创建登录用户变量
        • 获取访问用户变量
        • 获取埋点数量限额
      • 数据管理API(GDPR)
        • 数据保护
        • 删除原始数据
  • 产品使用文档
    • 产品分析
      • 数据监测
        • 概览
        • 实时
        • 分析看板
        • KPI看板
        • 小程序看数助手
      • 分析工具
        • 事件分析
          • 什么是事件分析
          • 创建事件分析
          • 视图介绍
        • 漏斗分析
          • 什么是漏斗分析
          • 创建漏斗分析
          • 漏斗分析结果解读
          • 案例解读
        • 留存分析
          • 什么是留存分析
          • 创建留存分析
          • 留存分析结果解读
          • 视图介绍
          • 应用场景
          • 常见问题
        • 分布分析
          • 什么是分布分析
          • 使用场景
          • 创建分布分析
        • 热图分析
          • 什么是热图分析
          • Web端热图
          • App热图
        • 事件流分析
      • 业务场景
        • 分享分析
        • 留存魔法师
    • 智能运营
    • 获客分析
      • 首页
        • 应用级数据
        • 数据指标说明
      • 分析
        • 渠道价值分析
        • 渠道归因分析
        • 落地页分析
        • 活动页分析
      • 获客追踪
        • 监测链接
          • 推广App
          • 推广网页
          • 推广小程序(微信)
            • 推广链接的投放和设置指南
            • 小程序码管理
        • 深度链接
        • 结合产品数据深度分析
      • 产品配置
        • 广告活动管理
        • 推广渠道管理
        • 深度链接配置
        • 广告数据权限控制
        • 日志数据导出
        • 维度配置(链接扩展维度)
        • 归因配置
      • 渠道配置指南
        • 苹果广告投放
        • 华为应用商oCPD
        • HUAWEI Ads
        • 腾讯社交广告(Marking API)
        • 今日头条(巨量纵横)
        • 百度原生信息流
        • 百度搜索_ocpc
        • 微信广告平台
        • 微博超级粉丝通
        • 爱奇艺
        • InMobi
        • 快手平台
        • 凤羽广告平台
        • bilibili(B站)
        • VIVO营销平台
      • 相关知识
        • UTM参数使用指南
        • 移动端转化归因
        • 默认的渠道来源跟踪
        • DeepLink启用新域名
      • 常见问题
    • 用户库
      • 用户分群
        • 用户分群
          • 什么是用户分群
          • 创建用户分群
            • 规则分群
          • 更新用户分群
          • 查看分群详情页
          • 常见问题
        • 用户细查
          • 什么是用户细查
          • 细查用户
          • 应用场景
          • 常见问题
      • 用户标签 - Beta
        • 创建标签
        • 标签模型使用
          • 基础指标值
          • 最大值 / 最小值
          • 最初 / 最终
          • 分层标签
      • 用戶分析
        • 活跃用户分析
          • 什么是活跃用户分析
          • 分析活跃用户
      • 业务场景
        • 微信应用用户分析
    • 数据中心
      • 数据管理
        • 无埋点事件
          • 概述
          • Web端数据定义
            • Web圈选
            • Chrome插件圈选
            • Chrome插件安装步骤
          • App端数据定义
          • App端数据定义(App圈选)
          • 小程序数据定义
          • 微信内嵌页数据定义
        • 埋点事件
        • 事件级变量
        • 页面级变量
        • 用户变量
          • 登录用户变量
          • 访问用戶变量
        • 转化变量
        • 业务标签管理
        • 批量操作
        • 自定义指标管理
          • 计算指标
          • 合并事件
        • 预定义维度
        • 预定义指标
      • 数据规划
        • 电商行业数据规划
      • 数据校验
        • 移动端数据校验
        • 小程序数据校验
        • Mobile Debugger
        • Web Debugger
      • 数据集成
        • 微信公众号集成
    • 项目管理
      • 如何进入项目管理?
      • 项目概览
      • 应用管理
      • 成员管理
      • 角色管理
        • 典型角色应用场景
        • 系统角色功能权限列表
      • 小组管理
      • 数据权限
      • 项目配置
        • IP及域名数据过滤
        • 爬虫预防
        • UTM映射管理
        • API Token管理
        • 获取项目UID
    • 组织管理
      • 组织概览
      • 组织项目
      • 组织成员
      • 费用中心(计费方案)
    • 个人中心
      • 个人信息
      • 安全设置
    • 学习平台
    • 工单管理
      • 提交工单
      • 查看进度
      • 邀请技术支持
    • 术语解释
  • 常见问题与解决
    • 基本问题
    • SDK集成
    • 圈选问题
    • 指标和维度
    • 数据安全
    • 产品使用
    • 数据统计差异
    • 如何删除不要的项目?
    • 为何收不到GIO的邮件?
    • 无效指标清理说明
    • 产品维护计划通告
由 GitBook 提供支持
在本页
  • 1. GrowingIO SDK无埋点采集的原理是什么?
  • 2. GrowingIO SDK 支持哪些iOS系统?
  • 3. SDK与其他SDK冲突报错,集成其他SDK后不采集数据,SDK开启debug模式无日志输出,APP在部分机型上没有采集到数据,该如何处理?
  • 4. 如果动态添加UIView、删除UIView或者修改UIView在父视图中的位置,会有什么影响?
  • 5. 子线程操作UI引起的问题如何处理?
  • 6. 圈选时,来自不同VC的元素显示的VC名称相同?
  • 7. 是否允许设置view的growingAttributesValue为单个数字或者字母?
  • 8. 埋点为什么也要在主线程调用?
  • 9. 是否支持在开启热图的时候圈选?
  • 10. 是否支持用UITouch事件的点击事件?
  • 11. GIO SDK是否支持Swift项目?
  • 12. App做了Button防重复点击,集成SDK后发现按钮无法点击?
  • 13. 如果项目中使用了Firebase SDK,需要注意什么?
  • 14. 关于苹果隐私政策相关事宜的公告
  • 15. 圈选扫码无法唤起 App

这有帮助吗?

  1. 开发者文档
  2. SDK 集成
  3. 原生 iOS SDK

常见问题

上一页iOS SDK升级指导下一页用户运营iOS SDK地址

最后更新于2年前

这有帮助吗?

1. GrowingIO SDK无埋点采集的原理是什么?

实现原理: ( method swizzling 作用为替换或者修改系统方法),可理解为以下 5 个步骤。

  1. 在系统方法M1中插入GIO代码GIO_B1

  2. 系统方法 M1 被执行,此时也会执行 GIO_B1

  3. 在 GIO_B1 内遍历 View Tree / DOM Tree 以及 UIViewController 的层次关系以获取必要的数据

  4. 生成待发送事件并缓存

  5. 发送事件到服务器,完成采集

2. GrowingIO SDK 支持哪些iOS系统?

支持iOS 8 以上,并持续更新适配最新版

3. SDK与其他SDK冲突报错,集成其他SDK后不采集数据,SDK开启debug模式无日志输出,APP在部分机型上没有采集到数据,该如何处理?

SDK 支持两种采集模式 Method Swizzling 和 KVO,默认情况下为 KVO。如果您出现问题中的情况,请按照下面方法尝试解决:在 main 方法实现的第一行中添加 [Growing setAspectMode:GrowingAspectModeDynamicSwizzling]; 。如果工程是Swift 语言开发的,在 UIAPplicationMain 函数上方添加 Growing.setAspectMode(.dynamicSwizzling)

4. 如果动态添加UIView、删除UIView或者修改UIView在父视图中的位置,会有什么影响?

SDK 依赖 subviews 里面的元素次序。如果有动态的需求,建议在 viewDidLoad 里加载所有可能的 UIView 节点,添加或删除可以通过设置 hidden 属性来实现,把不需要显示的设置 hidden 属性为 YES,把需要显示的设置 hidden 属性为 NO。在 UIView 已经显示之后,不要调用 -bringSubviewToFront:方法, -sendSubviewToBack:方法或 -insertSubview: 方法。

5. 子线程操作UI引起的问题如何处理?

6. 圈选时,来自不同VC的元素显示的VC名称相同?

这种情况,一般是因为父 VC 添加子 VC 方式不正确引起的,请客户排查子VC的生命周期是否完整。

7. 是否允许设置view的growingAttributesValue为单个数字或者字母?

不允许这种设置。出于安全考虑,金融类 App 会自定义键盘(默认键盘容易被黑),如果 SDK 允许采集 V 值为单个数字或字母的点击事件,则有可能会记录用户输入的账号或密码。由于上述原因, SDK 不会发送V 值为单个字母或数字的点击事件,如果用户违反约定,则会导致某个元素只有浏览量而没有点击量。

8. 埋点为什么也要在主线程调用?

埋点采集UI操作,建议在UI线程(主线程)中调用。

9. 是否支持在开启热图的时候圈选?

不支持,开启热图可能会导致被圈选元素的 x 值发生变化。

10. 是否支持用UITouch事件的点击事件?

不支持,建议使用 UITapGestureRecognizer

11. GIO SDK是否支持Swift项目?

支持

12. App做了Button防重复点击,集成SDK后发现按钮无法点击?

如果您的UIButton 防重复方案中, hook了 UIControl 的 originalSelector:@selector(sendAction:to:forEvent:) 方法,请确保在您的 swizzledSelector:@selector(your_swizzled_sendAction:to:forEvent:) 方法前面执行 如下代码:

- (void)your_swizzled_sendAction:(SEL)action to:(id)target forEvent:(UIEvent *)event {
     
      //  Called before your  extra work
       if ([NSStringFromClass([target class]) isEqualToString:@"GrowingUIControlObserver"]) { 
              [self your_swizzled_sendAction:action to:target forEvent:event]; // call origin
              return;
       }

       // Do your extra work. such as judge click interval....

       [self your_swizzled_sendAction:action to:target forEvent:event]; // call origin
}

如果还是无法点击,请联系技术支持。

13. 如果项目中使用了Firebase SDK,需要注意什么?

如果您的iOS项目中集成了Firebase SDK,请确保使用的Firebase SDK版本在4.8.1及以上,否则会造成数据采集不到的情况。

当您的Firebase SDK版本符合要求,但是没有发送vst事件时,请将采集模式改为hook模式。

修改方法:

Object-C:修改main.m文件:

Swift:修改AppDelegate.swift,并手动创建main.swift文件。

14. 关于苹果隐私政策相关事宜的公告

亲爱的客户:

您好!

从2018年10月3日开始,App Store Connect将要求所有新应用和应用更新版本时提供隐私政策,添加后才可以在App Store上提交或通过TestFlight外部测试进行分发。

所以,在此提醒各位开发者:提交App Store 审核前一定要准备自己的隐私权政策,并在app SafariViewContoller中弹出,否则会无法通过审核哦!如需要专业的法律意见,还请各位开发者小伙伴咨询您的律师或法律顾问哦!

15. 圈选扫码无法唤起 App

答:GIO SDK 会在主线程中遍历找寻某个subView,如果此时在子线程中删除了该subView,就会造成错乱甚至 crash。此外,Apple 不建议用户在子线程更新 UI。建议客户在 Xcode 中打开 "Main Thread Checker" 检测线程使用是否合理。参考:

【苹果通知:As a reminder, in June the App Store Review Guidelines were updated to require a privacy policy for all new apps and app updates as part of the app review process. Starting October 3, 2018, App Store Connect will require a privacy policy for all new apps and app updates before they can be submitted for distribution on the App Store or through TestFlight external testing. In addition, your app’s privacy policy link or text will only be editable when you submit a new version of your app.(详情可参见: )。

如果您在圈选或 Mobile Debugger 扫码验证时无法唤起 App,请核对 URL Scheme 是否配置正确,+[Growing handleUrl:] 函数调用是否正常,参考、

Method Swizzling
Main Thread Checker
https://developer.apple.com/news/?id=08312018a
添加 URL Scheme
添加激活圈选的代码
其他圈选问题