Menggunakan Analytics pada WebView di iOS

Panggilan untuk mencatat peristiwa ke dalam log atau menetapkan properti pengguna yang diaktifkan dari dalam WebView harus diteruskan ke kode native sebelum dapat dikirimkan ke Google Analytics for Firebase.

Menerapkan pengendali JavaScript

Langkah pertama dalam menggunakan Google Analytics for Firebase melalui WebView adalah membuat function JavaScript untuk meneruskan peristiwa dan properti pengguna ke kode native. Contoh berikut menunjukkan cara melakukan hal ini menggunakan prosedur yang sesuai dengan kode native Android dan iOS:
function logEvent(name, params) {
  if (!name) {
    return;
  }

  if (window.AnalyticsWebInterface) {
    // Call Android interface
    window.AnalyticsWebInterface.logEvent(name, JSON.stringify(params));
  } else if (window.webkit
      && window.webkit.messageHandlers
      && window.webkit.messageHandlers.firebase) {
    // Call iOS interface
    var message = {
      command: 'logEvent',
      name: name,
      parameters: params
    };
    window.webkit.messageHandlers.firebase.postMessage(message);
  } else {
    // No Android or iOS interface found
    console.log("No native APIs found.");
  }
}

function setUserProperty(name, value) {
  if (!name || !value) {
    return;
  }

  if (window.AnalyticsWebInterface) {
    // Call Android interface
    window.AnalyticsWebInterface.setUserProperty(name, value);
  } else if (window.webkit
      && window.webkit.messageHandlers
      && window.webkit.messageHandlers.firebase) {
    // Call iOS interface
    var message = {
      command: 'setUserProperty',
      name: name,
      value: value
   };
    window.webkit.messageHandlers.firebase.postMessage(message);
  } else {
    // No Android or iOS interface found
    console.log("No native APIs found.");
  }
}

Menerapkan antarmuka native

Untuk menjalankan kode iOS native dari JavaScript, buat class pengendali pesan yang sesuai dengan protokol WKScriptMessageHandler. Anda dapat melakukan panggilan Google Analytics for Firebase di dalam callback userContentController:didReceiveScriptMessage::

Swift

func userContentController(_ userContentController: WKUserContentController,
                         didReceive message: WKScriptMessage) {
  guard let body = message.body as? [String: Any] else { return }
  guard let command = body["command"] as? String else { return }
  guard let name = body["name"] as? String else { return }

  if command == "setUserProperty" {
    guard let value = body["value"] as? String else { return }
    Analytics.setUserProperty(value, forName: name)
  } else if command == "logEvent" {
    guard let params = body["parameters"] as? [String: NSObject] else { return }
    Analytics.logEvent(name, parameters: params)
  }
}

Objective-C

- (void)userContentController:(WKUserContentController *)userContentController
      didReceiveScriptMessage:(WKScriptMessage *)message {
  if ([message.body[@"command"] isEqual:@"setUserProperty"]) {
    [FIRAnalytics setUserPropertyString:message.body[@"value"] forName:message.body[@"name"]];
  } else if ([message.body[@"command"] isEqual: @"logEvent"]) {
    [FIRAnalytics logEventWithName:message.body[@"name"] parameters:message.body[@"parameters"]];
  }
}

Terakhir, tambahkan pengendali pesan ke pengontrol konten pengguna WebView:

Swift

self.webView.configuration.userContentController.add(self, name: "firebase")

Objective-C

 [self.webView.configuration.userContentController addScriptMessageHandler:self
                                                                     name:@"firebase"];

Langkah Berikutnya

Untuk melihat implementasi Google Analytics for Firebase yang berfungsi sepenuhnya di WebView, lihat contoh analytics-webview.

Kirim masukan tentang...

Butuh bantuan? Kunjungi halaman dukungan kami.