【Flutter】webview_flutter使用详解

文章目录


前言

webview_flutter是Flutter官方推出的一款用于Flutter上的webview插件,该插件在 iOS 用的是WKWebView 支持; 在 Android 上用的是系统WebView。

插件地址:https://pub.dev/packages/webview_flutter


一、如何使用

第一步:在项目根目录下运行如下命令配置依赖

flutter pub add webview_flutter

第二步:导入

在需要使用WebView的页面添加:

import 'package:webview_flutter/webview_flutter.dart';

第三步:初始化一个WebViewController

dart 复制代码
@override
  void initState() {
    super.initState();
    _initWebViewController();
  }

  void _initWebViewController() {
    controller = WebViewController()
      ..setJavaScriptMode(JavaScriptMode.unrestricted)
      ..setBackgroundColor(const Color(0x00000000))
      ..setNavigationDelegate(
        NavigationDelegate(
          onProgress: (int progress) {
		// Update loading bar.
          },
          onPageStarted: (String url) {},
          onPageFinished: (String url) {
		//页面加载完成后才能执行js
            _handleBackForbid();
          },
          onWebResourceError: (WebResourceError error) {},
          onNavigationRequest: (NavigationRequest request) {
            return NavigationDecision.navigate;
          },
        ),
      )
      ..loadRequest(Uri.parse('https://www.geekailab.com'));
  }
  

第四步:将WebViewController传递给WebViewWidget

dart 复制代码
@override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('Flutter Simple Example')),
      body: WebViewWidget(controller: controller),
    );
  }

API说明

WebViewController提供的API

dart 复制代码
///是否启用JavaScript执行,默认不启用
Future<void> setJavaScriptMode(JavaScriptMode javaScriptMode);
///设置webview的背景色
Future<void> setBackgroundColor(Color color);
/// 当WebView的导航状态发生变化时会回调此方法,在此法中可以进行跳转拦截;
/// 这里的 NavigationDecision.prevent表示阻止路由替换,NavigationDecision.navigate表示允许路由替换
Future<void> setNavigationDelegate(NavigationDelegate delegate);
///加载一个URL
/// uri:可以通过Uri.parse(url)来将url转成uri
/// method:支持get请求和post请求两种,默认为get
/// headers:发起url加载是携带的header信息,根据请求的网站要求进行传递
/// body:发起url请求是携带的body信息,可空
Future<void> loadRequest(
	Uri uri, {
	LoadRequestMethod method = LoadRequestMethod.get,
	Map<String, String> headers = const <String, String>{},
	Uint8List? body,
})
///设置WebView 是否应支持使用其屏幕缩放控件和手势进行缩放,默认支持;
Future<void> enableZoom(bool enabled);
///用于设置HTTP User-Agent: 请求标头的值
Future<void> setUserAgent(String? userAgent);
///返回此 WebView 的历史记录。
/// 如果没有返回历史记录项,则这是一个无操作。
Future<void> goBack();
/// 返回 WebView 正在显示的当前 URL。
/// 如果没有加载过 URL,则返回 `null`。
Future<String?> currentUrl();
///运行JS代码,javaScript,要运行的JS代码
Future<void> runJavaScript(String javaScript);
/// 运行JS代码并接收运行结果
/// javaScriptString:要运行的JS代码
/// 返回:JS运行的结果
Future<Object> runJavaScriptReturningResult(String javaScript);
/// 重新加载当前URL
Future<void> reload();
/// 判断是否可以返回历史记录的上一页
Future<bool> canGoBack();
/// 返回历史记录的上一页
Future<void> goBack();
/// 判断是否可以去往历史记录的下一页
Future<bool> canGoForward();
///跳转到历史记录的下一页
Future<void> goForward();
相关推荐
晚烛1 小时前
CANN + 物理信息神经网络(PINNs):求解偏微分方程的新范式
javascript·人工智能·flutter·html·零售
一起养小猫2 小时前
Flutter for OpenHarmony 实战:扫雷游戏完整开发指南
flutter·harmonyos
晚烛2 小时前
CANN 赋能智慧医疗:构建合规、高效、可靠的医学影像 AI 推理系统
人工智能·flutter·零售
晚霞的不甘2 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
小哥Mark4 小时前
Flutter开发鸿蒙年味 + 实用实战应用|绿色烟花:电子烟花 + 手持烟花
flutter·华为·harmonyos
一只大侠的侠5 小时前
Flutter开源鸿蒙跨平台训练营 Day 3
flutter·开源·harmonyos
一只大侠的侠6 小时前
【Harmonyos】Flutter开源鸿蒙跨平台训练营 Day 2 鸿蒙跨平台开发环境搭建与工程实践
flutter·开源·harmonyos
微祎_7 小时前
Flutter for OpenHarmony:构建一个 Flutter 平衡球游戏,深入解析动画控制器、实时物理模拟与手势驱动交互
flutter·游戏·交互
ZH15455891318 小时前
Flutter for OpenHarmony Python学习助手实战:面向对象编程实战的实现
python·学习·flutter
renke33649 小时前
Flutter for OpenHarmony:构建一个 Flutter 色彩调和师游戏,RGB 空间探索、感知色差计算与视觉认知训练的工程实现
flutter·游戏