[iOS]— イベントの送信方法について理解する
Usage
イベントの種類
KARTE では目的に応じてview
identify
track
の3つのイベント送信メソッドを提供しています。
画面の表示イベントを送信する
ある画面の表示(閲覧)したことをイベントとして送信する場合は、view
メソッドを利用します。
第1引数には、画面を一意に識別するための識別子(view_name)を指定します。
第2引数には、画面の名称(タイトル)を指定します。
このメソッドを利用して送信するイベントはview
イベントと呼ばれます。
🚧
viewイベントの注意点
viewイベントへのview_nameの付与は必須です。付与されない場合KARTEにviewイベントは送信されません。
※viewイベントへのtitleは実装観点での必須項目ではありませんが、運用観点(KARTE管理画面用での視認性のため)で、特別な理由がない限りは付与を推奨しています。
Tracker.view("signup", title: "会員登録")
[KRTTracker view:@"signup" title:@"会員登録"];
なお画面の表示イベントの送信は、track メソッドの第1引数にview
を指定して行うことも可能です。
下記コードは、上記コードと同等の意味合いとなります。
Tracker.track("view", values: [ "view_name": "signup", "title": "会員登録"])
[KRTTracker track:@"view" values:@{ @"view_name": @"signup", @"title": @"会員登録"}];
view メソッドの仕様については、リファレンス をご覧ください。
👍
Viewメソッドの実装位置
viewDidAppear(_:)
に実装することを推奨します。
ユーザーの情報を送信する
ユーザーに紐付く情報(ユーザーIDや名前、年齢等)を送信する場合は、identify
メソッドを利用します。
第1引数には、ユーザーのIDを指定します。
第2引数には、ユーザーに紐付ける情報を指定します。
このメソッドを利用して送信するイベントはidentify
イベントと呼ばれます。
🚧
identifyイベントの注意点
identifyイベントへのuser_idの付与は必須です。付与されない場合KARTEにidentifyイベントは送信されません。
user_idの確定前にユーザーに紐づく情報を送信する場合attributeイベント を使用してください。
なお、attributeイベント には個人情報を含めないよう十分にご注意ください。
詳細は個人情報関連イベントの特別な仕様についてを参照ください。
Tracker.identify( "karte_taro", ["name": "カルテ太郎"])
[KRTTracker identify:@"ユーザーID" :@{ @"name": @"KARTE太郎"}];
なおidentify
イベントの送信は、track メソッドの第1引数にidentify
を指定して行うことも可能です。
下記コードは、上記コードと同等の意味合いとなります。
Tracker.track("identify", values: [ "user_id": "karte_taro", "name": "カルテ太郎"])
[KRTTracker track:@"identify" values:@{ @"user_id": @"karte_taro", @"name": @"カルテ太郎"}];
identify メソッドの仕様については、リファレンス をご覧ください。
任意の行動イベントを送信する
画面の表示やユーザー情報以外の行動情報について送信する場合は、track
メソッドを利用します。
第1引数には、行動を表すイベント名を指定します。
第2引数には、行動に紐付く情報を任意で指定します。
このメソッドを利用して送信するイベントはカスタムイベントと呼ばれます。
Tracker.track("favorite", values: [ "id": "P00003", "name": "ミネラルウォーター(500ml)", "price": 100])
[KRTTracker track:@"favorite" values:@{ @"id": @"P00003", @"name": @"ミネラルウォーター(500ml)", @"price": @(100)}];
track メソッドの仕様については、リファレンス をご覧ください。
📘
イベント名の制限と予約済みのイベント名
イベント名には制限があります。
詳細については、イベント名の制限 をご覧ください。また一部のイベント名は予約されており、KARTE上で特別な扱いを受けます。
詳細については、定義済みイベント をご覧ください。
イベントに付与可能な値の型
各イベントの送信メソッドには、任意で Dictionary を渡すことが可能です。
これによりイベントに様々なフィールドを紐付けて送信することが可能になります。
なお Dictionary のKey
およびValue
には制限があります。
Keyとして利用可能な型
String
またはNSString
型の値のみ利用可能です。
📘
フィールド名の制限
フィールド名には制限があります。
詳細については、フィールド名の制限 をご覧ください。
Valueとして利用可能な型
下記表に記載の型のみ利用可能です。
なお日付型は内部的に浮動小数点型に変換された上で送信されます。
種別 | 型 |
---|---|
文字列 | String NSString |
整数(符号あり) | Int Int8 Int16 Int32 Int64 NSNumber |
整数(符号なし) | UInt UInt8 UInt16 UInt32 UInt64 NSNumber |
浮動小数点数 | Double Float CGFlaot NSNumber |
真偽値 | Bool NSNumber |
日付 | Date NSDate |
辞書 | Dictionary NSDictionary |
配列 | Array NSArray |
Updated 11 days ago