flutter 使用webview

背景:

一般都有使用webview加载网页的需求,比如加载隐私协议、用户协议等。

如何做:

当然,我们自己不用封装轮子,在pub.dev上有成熟的轮子:webview_flutter

首先,将依赖导入,在pubspec.yaml文件中:

Dart 复制代码
webview_flutter: ^4.4.3

这里我用的不是最新版本,因为我本地的dart sdk版本是3.0.5,考虑兼容性,我使用的是webview_flutter:4.4.3版本。

第二步,新建一个文件:

Dart 复制代码
import 'package:flutter/material.dart';
import 'package:videoshort/util/UtilString.dart';
import 'package:webview_flutter/webview_flutter.dart';

class WebViewPage extends StatefulWidget {
  const WebViewPage({super.key});

  @override
  State<WebViewPage> createState() => _WebViewPageState();
}

class _WebViewPageState extends State<WebViewPage> {
  late WebViewController _controller;

  @override
  void initState() {
    super.initState();
    _controller = WebViewController()
      ..setJavaScriptMode(JavaScriptMode.unrestricted)
      ..setBackgroundColor("#FFFFFF".hexToColor())..setNavigationDelegate(NavigationDelegate(onProgress: (int progress){
        "onProgress $progress".log();
      },onPageStarted: (String url){
        "onPageStarted $url".log();
      },onPageFinished: (String url){
        "onPageFinished $url".log();
      },onWebResourceError: (WebResourceError error) {
        "Error ${error.description}".log();
      },onNavigationRequest: (NavigationRequest request){
        if (request.url.startsWith('https://www.youtube.com/')) {
          return NavigationDecision.prevent;
        }
        return NavigationDecision.navigate;
      }))..loadRequest(Uri.parse("https://www.baidu.com"),method: LoadRequestMethod.get);
  }

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

基本到这一步,就已经完成了webview的使用,url和title可以从外部进行传参。

如何加载http的问题

跳转WebView报错net::ERR_CLEARTEXT_NOT_PERMITTED:

在加载http的网页时,会遇到上面的报错,原因是:从Android 9.0(API级别28)开始,默认情况下禁用明文支持。因此http的url均无法在webview中加载。

如何处理:

打开android目录中的AndroidManifest.xml文件(一般路径为:android/app/src/main/AndroidManifest.xml),并在application标签中添加如下一行代码
android:usesCleartextTraffic="true",注意添加的位置,如下图:

注意,在fluter工程目录中,还有一个debug目录下也有androidManifest.xml文件,两个最好都添加上。

最后,可以卸载应用,重新安装。

完结撒花!

相关推荐
shr007_2 小时前
flutter 鸿蒙
flutter·华为·harmonyos
Bryce李小白2 小时前
Flutter 与原生混合编程
flutter
wahkim6 小时前
移动端开发工具集锦
flutter·ios·android studio·swift
傅里叶6 小时前
Flutter / Dart 多包管理工具 —— Melos 使用指南
flutter
西西学代码8 小时前
Flutter---生命周期
flutter
LiWeNHuI10 小时前
Flutter开发:发布插件到Pub
flutter
衿璃12 小时前
Flutter应用架构设计的思考
前端·flutter
QuantumLeap丶14 小时前
《Flutter全栈开发实战指南:从零到高级》- 04 - Widget核心概念与生命周期
flutter·xcode
勤劳打代码15 小时前
触类旁通 —— Flutter 与 React 对比解析
前端·flutter·react native
消失的旧时光-19431 天前
Flutter Event Loop
flutter