Flutter网页视图与页面调用插件webview_flutter_pagecall_poc的使用
在Flutter应用中,嵌入网页是非常常见的需求。webview_flutter
插件提供了强大的功能来实现这一需求,并且可以通过 webview_flutter_pagecall_poc
插件实现网页与Flutter页面之间的双向通信。
1. 引入依赖
首先,在 pubspec.yaml
文件中添加 webview_flutter
和 webview_flutter_pagecall_poc
的依赖:
dependencies:
flutter:
sdk: flutter
webview_flutter: ^4.0.0
webview_flutter_pagecall_poc: ^1.0.0
然后运行 flutter pub get
来安装这些依赖。
2. 配置 Android 和 iOS
Android
确保 minSdkVersion
至少为 19:
android {
defaultConfig {
minSdkVersion 19
}
}
iOS
确保 Xcode 版本支持 WKWebView(通常 Xcode 10 及以上)。
3. 基本使用示例
以下是一个完整的示例代码,展示如何使用 webview_flutter
和 webview_flutter_pagecall_poc
插件:
// 导入必要的库
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
import 'package:webview_flutter_pagecall_poc/webview_flutter_pagecall_poc.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: WebViewPage(),
);
}
}
class WebViewPage extends StatefulWidget {
@override
_WebViewPageState createState() => _WebViewPageState();
}
class _WebViewPageState extends State<WebViewPage> {
late WebViewController _controller;
@override
void initState() {
super.initState();
// 初始化 WebView 控制器
_controller = WebViewController()
..setJavaScriptMode(JavaScriptMode.unrestricted)
..setNavigationDelegate(NavigationDelegate(
onProgress: (int progress) {
print('Loading progress: $progress%');
},
onPageStarted: (String url) {
print('Page started loading: $url');
},
onPageFinished: (String url) {
print('Page finished loading: $url');
},
))
..loadRequest(Uri.parse('https://example.com'));
// 添加 PageCall 支持
_controller.addPageCallHandler((message) {
print('Received message from web: $message');
return 'Response from Flutter';
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('WebView with PageCall'),
),
body: WebViewWidget(controller: _controller),
);
}
}
4. 关键功能说明
4.1 加载网页
通过 WebViewController.loadRequest()
方法加载指定的 URL 或本地文件。
_controller.loadRequest(Uri.parse('https://example.com'));
4.2 设置 JavaScript 模式
允许或禁止执行 JavaScript:
_controller.setJavaScriptMode(JavaScriptMode.unrestricted);
4.3 页面导航拦截
通过 NavigationDelegate
拦截页面跳转请求:
_navigationDelegate: NavigationDelegate(
onNavigationRequest: (NavigationRequest request) {
if (request.url.startsWith('https://youtube.com')) {
return NavigationDecision.prevent; // 阻止跳转到 YouTube
}
return NavigationDecision.navigate; // 允许其他跳转
},
),
4.4 双向通信(PageCall)
使用 addPageCallHandler
注册一个处理函数,用于接收来自网页的消息并返回响应。
_controller.addPageCallHandler((message) {
print('Received message from web: $message');
return 'Response from Flutter';
});
在网页端可以调用以下 JavaScript 代码发送消息:
window.flutter_inappwebview.callHandler('pageCallHandler', 'Hello from web!');
5. 完整 Demo 效果
运行上述代码后,您将看到一个带有 WebView 的页面,能够加载指定的网页并支持从网页向 Flutter 传递消息。同时,您可以点击按钮触发 Flutter 向网页发送响应。
6. 注意事项
-
权限设置:确保您的 AndroidManifest.xml 文件中包含网络访问权限:
<uses-permission android:name="android.permission.INTERNET"/>
-
调试模式:在 Android 上启用 WebView 调试功能(可选):
AndroidWebViewController.enableDebugging(true);
更多关于Flutter网页视图与页面调用插件webview_flutter_pagecall_poc的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
在Flutter中,webview_flutter
是一个常用的插件,用于在应用中嵌入网页视图。而 webview_flutter_pagecall_poc
是一个基于 webview_flutter
的插件,用于在网页视图和Flutter页面之间进行通信和调用。
1. 添加依赖
首先,你需要在 pubspec.yaml
文件中添加 webview_flutter
和 webview_flutter_pagecall_poc
的依赖:
dependencies:
flutter:
sdk: flutter
webview_flutter: ^4.0.0
webview_flutter_pagecall_poc: ^1.0.0
然后运行 flutter pub get
来获取依赖。
2. 基本使用
以下是一个简单的示例,展示如何使用 webview_flutter_pagecall_poc
插件在Flutter中嵌入网页视图,并在网页和Flutter之间进行通信。
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
import 'package:webview_flutter_pagecall_poc/webview_flutter_pagecall_poc.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: WebViewExample(),
);
}
}
class WebViewExample extends StatefulWidget {
@override
_WebViewExampleState createState() => _WebViewExampleState();
}
class _WebViewExampleState extends State<WebViewExample> {
late WebViewController _controller;
late PageCallHandler _pageCallHandler;
@override
void initState() {
super.initState();
_pageCallHandler = PageCallHandler(
onPageCall: (String method, dynamic arguments) async {
// 处理从网页调用的方法
if (method == 'showMessage') {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text('Message from Web: $arguments')),
);
}
return null;
},
);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('WebView PageCall POC'),
),
body: WebView(
initialUrl: 'https://your-webpage.com',
javascriptMode: JavascriptMode.unrestricted,
onWebViewCreated: (WebViewController webViewController) {
_controller = webViewController;
_pageCallHandler.attachToWebView(_controller);
},
javascriptChannels: <JavascriptChannel>{
_pageCallHandler.javascriptChannel,
},
),
floatingActionButton: FloatingActionButton(
onPressed: () async {
// 调用网页中的JavaScript方法
await _controller.evaluateJavascript('callFromFlutter("Hello from Flutter!")');
},
child: Icon(Icons.send),
),
);
}
}
3. 解释代码
- WebView: 使用
webview_flutter
插件嵌入网页视图。 - PageCallHandler: 使用
webview_flutter_pagecall_poc
插件处理网页和Flutter之间的通信。 - onPageCall: 当网页调用Flutter方法时,会触发此回调。你可以在这里处理来自网页的调用。
- javascriptChannels: 将
PageCallHandler
的JavascriptChannel
添加到WebView
中,以便网页可以调用Flutter方法。 - evaluateJavascript: 在Flutter中调用网页中的JavaScript方法。
4. 网页端代码
在网页中,你可以使用以下代码来调用Flutter方法:
function callFromFlutter(message) {
console.log('Received from Flutter:', message);
}
// 调用Flutter方法
window.flutter_inappwebview.callHandler('showMessage', 'Hello from Web!');