flutter webview js交互如何实现
我在Flutter项目中需要使用WebView加载网页,并实现与JavaScript的交互功能。具体需求是:通过WebView加载页面后,能够调用页面中的JS方法,同时也能让网页中的JS回调到Flutter端。请问应该如何实现这种双向通信?官方推荐的WebView插件是否支持这种功能?能否提供一个完整的代码示例,包括初始化WebView、注册JS回调以及调用JS方法的详细步骤?另外,在iOS和Android平台上是否有需要注意的差异?
2 回复
Flutter WebView JS交互可通过webview_flutter插件实现。在WebView中注入JavaScript代码,使用onPageFinished回调执行JS,或通过JavascriptChannel接收JS消息。双向通信使用evaluateJavascript发送数据,JS通过window.postMessage传递消息给Flutter。
更多关于flutter webview js交互如何实现的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
在Flutter中实现WebView与JavaScript交互主要通过webview_flutter插件实现。以下是具体实现步骤:
1. 添加依赖
dependencies:
webview_flutter: ^4.4.2
2. 基础实现代码
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
class WebViewJSInteraction extends StatefulWidget {
@override
_WebViewJSInteractionState createState() => _WebViewJSInteractionState();
}
class _WebViewJSInteractionState extends State<WebViewJSInteraction> {
late WebViewController controller;
String jsResult = '';
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text('WebView JS交互')),
body: Column(
children: [
// Flutter调用JS的按钮
ElevatedButton(
onPressed: () async {
// 执行JavaScript代码
final result = await controller.runJavaScript('return document.title;');
setState(() {
jsResult = result ?? '无结果';
});
},
child: Text('获取网页标题'),
),
Text('JS返回结果: $jsResult'),
Expanded(
child: WebView(
initialUrl: 'https://example.com',
onWebViewCreated: (WebViewController webViewController) {
controller = webViewController;
},
javascriptMode: JavascriptMode.unrestricted,
// JS调用Flutter的通道
javascriptChannels: <JavascriptChannel>{
JavascriptChannel(
name: 'Flutter',
onMessageReceived: (JavascriptMessage message) {
// 处理来自JS的消息
print('收到JS消息: ${message.message}');
setState(() {
jsResult = message.message;
});
},
),
},
),
),
],
),
);
}
}
3. Flutter调用JavaScript
// 执行简单JS代码
await controller.runJavaScript('alert("Hello from Flutter")');
// 执行带返回值的JS
final result = await controller.runJavaScriptReturningResult('1 + 1');
// 调用页面中的JS函数
await controller.runJavaScript('window.myJSFunction("参数")');
4. JavaScript调用Flutter
在HTML/JS中:
// 向Flutter发送消息
Flutter.postMessage('Hello from JavaScript');
// 调用Flutter并等待响应
function callFlutter() {
Flutter.postMessage(JSON.stringify({
type: 'getUserInfo',
data: '需要的数据'
}));
}
5. 完整交互示例
JavascriptChannel(
name: 'FlutterChannel',
onMessageReceived: (JavascriptMessage message) {
final data = json.decode(message.message);
switch (data['type']) {
case 'getUserInfo':
// 处理业务逻辑
final userInfo = {'name': '张三', 'age': 25};
// 将结果返回给JS
controller.runJavaScript('window.onFlutterResponse(${json.encode(userInfo)})');
break;
}
},
),
注意事项
- 确保启用JavaScript:
javascriptMode: JavascriptMode.unrestricted - 处理异步调用和错误
- 注意安全性,避免执行不受信任的JS代码
这样就实现了Flutter WebView与JavaScript的双向通信。

