flutter 专题 七十 Flutter应用开发之webview_flutter插件

devtools/2025/4/1 15:26:47/

简介

在移动应用开发中,经常会遇到加载网页的需求,打开网页通常有两种方式,即在应用内使用内置的组件打开和使用系统自带的浏览器打开。不过,在Flutter应用开发中,由于官方并没有提供类似Webview的网页加载组件,所以如果项目中涉及网页加载需要使用第三方插件库,如webview_flutterflutter_webview_plugin等。

其中,webview_flutter是Flutter官方开发和维护的网页加载插件库,而flutter_webview_plugin则是Flutter开源社区推出的网页加载插件。两个插件功能都差不多,都支持加载本地html文本、Flutter调用js以及js调用Flutter等,但是我建议使用官方推出的插件,因为它会持续的跟进已知的问题。

和其他Flutter插件的使用方式一样,使用webview_flutter之前需要先在pubspec.yaml文件中添加依赖脚本,如下所示。

dependencies:webview_flutter: ^0.3.22+1

然后,我们使用flutter packages get命令将webview_flutter插件拉取到本地后,就可以使用它进行网页加载开发了。

基本使用

如下所示,是WebView组件的构造函数。

WebView({Key key,this.onWebViewCreated,             //WebView创建完成之后的回调this.initialUrl,                               // 初始化 URLthis.javascriptMode = JavascriptMode.disabled,    //JS执行模式,默认是不调用this.javascriptChannels,             // JS可以调用Flutter 的通道this.navigationDelegate,            // 路由委托,可以使用它执行拦截操作this.gestureRecognizers,          // 手势相关this.onPageStarted,                 //开始加载页面回调this.onPageFinished,              // 页面加载完成的回调this.onWebResourceError,     //资源加载失败回调this.debuggingEnabled = false,this.gestureNavigationEnabled = false,this.userAgent,this.initialMediaPlaybackPolicy =AutoMediaPlaybackPolicy.require_user_action_for_all_media_types,})

使用时,只需要按照参数传递对应的值即可。不过,在实际使用前,为了方便使用,我们一般会对它进行二次封装,主要是界面和功能的封装。下面是我封装的一个可以加载本地和网络文件的WebViewPage。

class WebViewPage extends StatefulWidget {String url;final String title;final bool isLocalUrl;WebViewController _webViewController;WebViewPage({this.url, this.isLocalUrl = false, this.title});@override_WebViewPage createState() => _WebViewPage();}class _WebViewPage extends State<WebViewPage> {JavascriptChannel jsBridge(BuildContext context) => JavascriptChannel(name: 'jsbridge', // 与h5 端的一致 不然收不到消息onMessageReceived: (JavascriptMessage message) async{debugPrint(message.message);});@overrideWidget build(BuildContext context) {return Scaffold(appBar: _buildAppbar(),body: _buildBody());}_buildAppbar() {return AppBar(elevation: 0,backgroundColor: Color(0xccd0d7),title: Text(widget.title, style: TextStyle(color: Colors.black),),centerTitle: true,leading: IconButton(icon: Icon(Icons.arrow_back, color: Color(0xFF23ADE5),), onPressed: () {}));}_buildBody() {return Column(children: <Widget>[SizedBox(height: 1,width: double.infinity,child: const DecoratedBox(decoration: BoxDecoration(color: Color(0xFFEEEEEE))),),Expanded(flex: 1,child: WebView(initialUrl: widget.isLocalUrl ? Uri.dataFromString(widget.url, mimeType: 'text/html', encoding: Encoding.getByName('utf-8')).toString(): widget.url,javascriptMode: JavascriptMode.unrestricted,javascriptChannels: <JavascriptChannel>[jsBridge(context)].toSet(),onWebViewCreated: (WebViewController controller){widget._webViewController = controller;if(widget.isLocalUrl){_loadHtmlAssets(controller);}else{controller.loadUrl(widget.url);}controller.canGoBack().then((value) => debugPrint(value.toString()));controller.canGoForward().then((value) => debugPrint(value.toString()));controller.currentUrl().then((value) => debugPrint(value));},onPageFinished: (String value){widget._webViewController.evaluateJavascript('document.title').then((title) => debugPrint(title));},),)],);}//加载本地文件_loadHtmlAssets(WebViewController controller) async {String htmlPath = await rootBundle.loadString(widget.url);controller.loadUrl(Uri.dataFromString(htmlPath,mimeType: 'text/html', encoding: Encoding.getByName('utf-8')).toString());}}

使用时,只需要按照传入对应的属性即可。需要说明的是,加载本地Html文件时,需要在pubspec.yaml文件中申明这个Html文件,如下所示。

flutter://  ...assets:- assets/real_data_help.html

然后,我们使用封装的组件即可加载本地的Html文件。例如:

class MyApp extends StatelessWidget {String localUrl = 'assets/real_data_help.html';@overrideWidget build(BuildContext context) {return MaterialApp(title: 'Flutter Demo',theme: ThemeData(primarySwatch: Colors.blue,),home:WebViewPage(url:localUrl, isLocalUrl: true, title: '加载本地文件'),);}
}

运行代码,效果下图所示。


http://www.ppmy.cn/devtools/172376.html

相关文章

鸿蒙UI开发

鸿蒙UI开发 本文旨在分享一些鸿蒙UI布局开发上的一些建议&#xff0c;特别是对屏幕宽高比发生变化时的应对思路和好的实践。 折叠屏适配 一般情况&#xff08;自适应布局/响应式布局&#xff09; 1.自适应布局 1.1自适应拉伸 左右组件定宽 TypeScript //左右定宽 Row() { …

李想官宣开源整车操作系统

2025 年 3 月 27 日&#xff0c;在中关村论坛开幕式暨全体会议上&#xff0c;理想汽车董事长兼 CEO 李想宣布&#xff0c;将对自研车载操作系统理想星环 OS 进行开源&#xff0c;理想星环 OS 将于今年 4 月上线开源社区&#xff0c;理想汽车也因此成为全球第一家将车载操作系统…

Java面试黄金宝典22

1. 树的中序遍历&#xff0c;除了递归和栈还有什么实现方式 定义 Morris 遍历是一种用于二叉树遍历的算法&#xff0c;它利用树中大量空闲的空指针&#xff0c;在不使用额外栈空间和递归的情况下&#xff0c;完成树的遍历。通过建立临时的线索连接&#xff0c;使得可以按照中…

c++学习系列----006. c++模板(函数模板)

c 函数模板 文章目录 c 函数模板C 函数模板概念**函数模板**的作用&#xff1a; 函数模板语法示例&#xff1a;冒泡排序**代码解析****运行结果** 函数模板的优势小结 C 函数模板概念 函数模板是 C 中的一个泛型编程特性&#xff0c;它允许你为不同的类型编写一个通用的函数定…

数据结构与算法——顺序表之手撕OJ题

文章目录 一、前言二、拿捏OJ题2.1移除元素2.2删除有序数组中的重复项2.3合并两个有序数组 三、总结 一、前言 Do you study today?up在上一次已经讲解完毕了有关顺序表的所有知识&#xff0c;不知道大家是否已经沉淀完毕了呢&#xff1f;有一句老话说得好啊——光看不练假把…

Yolo系列之Yolov4的改进及网络框架

Yolov4的网络框架及改进对比 目录 Yolov4的网络框架及改进对比1 YOLOv41.1 概念1.2 核心特点1.3 优缺点 2 Bag of Freebies (BoF)2.1 概念2.2 数据增强2.3 网络正则化2.4 Label Smoothing标签平滑2.5 损失函数改进 3 Bag of Specials (BoS)3.1概念3.2 非极大值抑制的改进3.3 网…

C++异常处理完全指南:从原理到实战

文章目录 异常的基本概念基本异常抛出与捕获多类型异常捕获异常重新抛出异常安全异常规范&#xff08;noexcept&#xff09;栈展开与析构标准库异常总结 异常的基本概念 异常是程序运行时发生的非预期事件&#xff08;如除零、内存不足&#xff09;。C通过try、catch和throw提…

5G核心网(5GC)中5QI(5G QoS Identifier)

在5G核心网&#xff08;5GC&#xff09;中&#xff0c;**5QI&#xff08;5G QoS Identifier&#xff09;**是用于标识5G网络中不同服务质量&#xff08;QoS&#xff09;特性的关键参数。5QI通过定义一组QoS特性&#xff0c;帮助网络为不同的业务流分配资源并提供相应的服务质量…