Heim  >  Artikel  >  Web-Frontend  >  Wie nutzt die Uniapp-Implementierung JSBridge für die Interaktion mit Native?

Wie nutzt die Uniapp-Implementierung JSBridge für die Interaktion mit Native?

王林
王林Original
2023-10-20 08:44:241755Durchsuche

Wie nutzt die Uniapp-Implementierung JSBridge für die Interaktion mit Native?

uniapp implementiert die Verwendung von JSBridge für die Interaktion mit Native, was spezifische Codebeispiele erfordert

1 Hintergrundeinführung

Bei der Entwicklung mobiler Anwendungen ist es manchmal notwendig, mit der nativen Umgebung zu interagieren, z. B. einige native Funktionen aufzurufen oder einige native Daten erhalten. Als plattformübergreifendes Framework für die Entwicklung mobiler Anwendungen bietet uniapp eine bequeme Möglichkeit, mit nativen Geräten zu interagieren und JSBridge für die Kommunikation zu verwenden.

JSBridge ist eine technische Lösung für die Interaktion des Front-Ends mit dem mobilen Native-End. Durch die Implementierung einer Bridge auf dem Front-End bzw. dem Native-End kann das Front-End native Methoden aufrufen und native Daten abrufen Gleichzeitig können über die Bridge auch Informationen vom nativen Ende an das Front-End gesendet werden.

2. Implementierungsschritte von JSBridge

  1. Erstellen Sie eine neue js-Datei im Uniapp-Projekt und nennen Sie sie JSBridge.js. Diese Datei dient als Brücke zwischen den Front-End- und nativen Interaktionen.
  2. Definieren Sie ein globales Objekt in der Datei JSBridge.js, um Nachrichten und Rückruffunktionen zwischen dem Frontend und Native zu speichern. Der Beispielcode lautet wie folgt:
// JSBridge.js

let messageHandlers = {}; // 存储前端和原生之间的消息和回调函数

// 注册消息处理函数,前端通过调用此函数来注册对应的回调函数
function registerHandler(name, handler) {
  messageHandlers[name] = handler;
}

// 发送消息到原生
function sendMessageToNative(name, data, callback) {
  let message = {
    name: name,
    data: data
  };
  
  // 注册回调函数
  if (callback) {
    let callbackId = 'cb_' + Date.now();
    message.callbackId = callbackId;
    messageHandlers[callbackId] = callback;
  }
  
  // 向原生发送消息
  window.webkit.messageHandlers[name].postMessage(message);
}

// 处理原生发送过来的消息
function handleMessageFromNative(message) {
  let handler = messageHandlers[message.name];
  
  if (handler) {
    handler(message.data, function(response) {
      sendMessageToNative(message.callbackId, response); // 发送回调消息给原生
    });
  }
}

window.messageHandlers = messageHandlers;
window.registerHandler = registerHandler;
window.sendMessageToNative = sendMessageToNative;
window.handleMessageFromNative = handleMessageFromNative;
  1. Fügen Sie JSBridge.js in die Datei main.js im Uniapp-Projekt ein und registrieren Sie die Nachrichtenverarbeitungsfunktion wie folgt: main.js文件中引入JSBridge.js,并注册消息处理函数,示例代码如下:
// main.js

import JSBridge from './JSBridge.js';

// 注册消息处理函数,前端通过调用此函数来注册对应的回调函数
JSBridge.registerHandler('getUserInfo', function(data, callback) {
  console.log('前端收到getUserInfo消息:', data);
  
  // 假设需要获取用户信息,可以通过uniapp的API来实现
  let userInfo = uni.getUserInfo();
  
  // 返回获取到的用户信息给原生
  callback(userInfo);
});

// 假设页面上有一个按钮,点击按钮时调用原生的方法
document.getElementById('btn').addEventListener('click', function() {
  // 发送消息到原生
  JSBridge.sendMessageToNative('showAlert', { title: 'Hello', message: 'World' });
});
  1. 在原生环境中实现与前端交互的功能和逻辑。示例代码如下:
// 在iOS原生代码中

import WebKit

class ViewController: UIViewController {
  var webView: WKWebView!

  override func viewDidLoad() {
    super.viewDidLoad()
    
    // 创建WebView
    webView = WKWebView(frame: CGRect(x: 0, y: 0, width: view.bounds.width, height: view.bounds.height))
    view.addSubview(webView)
    
    // 加载uniapp的HTML文件
    if let url = Bundle.main.url(forResource: "uniapp", withExtension: "html") {
      webView.loadFileURL(url, allowingReadAccessTo: url)
    }
    
    // 注册JSBridge处理函数,用于处理前端发送来的消息
    webView.configuration.userContentController.add(self, name: "getUserInfo")
    webView.configuration.userContentController.add(self, name: "showAlert")
  }
}

extension ViewController: WKScriptMessageHandler {
  func userContentController(_ userContentController: WKUserContentController, didReceive message: WKScriptMessage) {
    if let body = message.body as? [String: Any] {
      let name = message.name
      
      if name == "getUserInfo" {
        print("原生收到getUserInfo消息:", body)
        
        // TODO: 获取原生的用户信息
        
        // 返回用户信息给前端
        let userInfo = [
          "name": "John",
          "age": 20
        ]
        let response = [
          "data": userInfo
        ]
        let javascript = "window.handleMessageFromNative((response))"
        webView.evaluateJavaScript(javascript, completionHandler: nil)
      }
      else if name == "showAlert" {
        print("原生收到showAlert消息:", body)
        
        // 假设实现一个弹窗功能
        let title = body["title"] as? String ?? ""
        let message = body["message"] as? String ?? ""
        let alertController = UIAlertController(title: title, message: message, preferredStyle: .alert)
        alertController.addAction(UIAlertAction(title: "OK", style: .default, handler: nil))
        present(alertController, animated: true, completion: nil)
      }
    }
  }
}

三、使用JSBridge进行前端与原生交互

通过上述的步骤,我们已经实现了基本的JSBridge桥梁和消息处理函数。在前端代码中,我们可以调用JSBridge.sendMessageToNative()方法向原生发送消息,同时也可以注册对应的消息处理函数,如示例中的JSBridge.registerHandler()。在原生代码中,我们通过userContentController.add()方法注册处理函数,用于接收前端发送的消息,并实现相应的功能。

在页面中,当点击按钮时,调用JSBridge.sendMessageToNative('showAlert', { title: 'Hello', message: 'World' })方法发送消息到原生,原生接收到消息后,弹出一个带有标题和内容的弹窗。另外,当前端需要获取用户信息时,调用JSBridge.sendMessageToNative('getUserInfo')

rrreee

    Implementieren Sie die Funktionen und die Logik der Interaktion mit dem Frontend in der nativen Umgebung. Der Beispielcode lautet wie folgt:

    rrreee

    3. Verwenden Sie JSBridge für Front-End- und native Interaktion 🎜🎜Durch die oben genannten Schritte haben wir die grundlegenden JSBridge-Bridge- und Nachrichtenverarbeitungsfunktionen implementiert. Im Front-End-Code können wir die Methode JSBridge.sendMessageToNative() aufrufen, um Nachrichten nativ zu senden, und wir können auch die entsprechende Nachrichtenverarbeitungsfunktion registrieren, z. B. JSBridge.registerHandler() im Beispielcode>. Im nativen Code registrieren wir die Verarbeitungsfunktion über die Methode userContentController.add(), um die vom Frontend gesendeten Nachrichten zu empfangen und die entsprechenden Funktionen zu implementieren. 🎜🎜Wenn auf der Seite auf die Schaltfläche geklickt wird, rufen Sie die Methode JSBridge.sendMessageToNative('showAlert', { title: 'Hello', message: 'World' }) auf, um die Nachricht an die zu senden native, und der native erhält sie. Nach der Nachricht wird ein Popup-Fenster mit Titel und Inhalt angezeigt. Wenn das Front-End Benutzerinformationen abrufen muss, ruft es außerdem die Methode JSBridge.sendMessageToNative('getUserInfo') auf, um eine Nachricht an den Native zu senden Das Frontend ruft die Daten über die Rückruffunktion ab und verarbeitet sie. 🎜🎜Zusammenfassend lässt sich sagen, dass mit JSBridge die Interaktion zwischen Uniapp und der nativen Umgebung problemlos realisiert und eigene Funktionen und Logik im Front-End bzw. nativ implementiert werden können. Durch die Registrierung von Nachrichtenverarbeitungsfunktionen können Nachrichten flexibel zugestellt und verarbeitet werden. 🎜🎜Das Obige ist eine kurze Einführung und Codebeispiele zur Verwendung von JSBridge zur Implementierung nativer Interaktion. Ich hoffe, es wird Ihnen hilfreich sein. 🎜

Das obige ist der detaillierte Inhalt vonWie nutzt die Uniapp-Implementierung JSBridge für die Interaktion mit Native?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn