首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在Flutter Webview中访问localStorage

在Flutter Webview中访问localStorage,首先需要确保WebView的设置允许JavaScript运行

以下是如何在Flutter中使用WebView的示例。首先,确保你已经在pubspec.yaml文件中添加了webview_flutter依赖:

代码语言:javascript
复制
dependencies:
  flutter:
    sdk: flutter
  webview_flutter: ^4.0.1

接下来,创建一个包含WebView的简单应用程序:

代码语言:javascript
复制
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: Text('WebView LocalStorage Example')),
        body: MyWebView(),
      ),
    );
  }
}

class MyWebView extends StatefulWidget {
  @override
  _MyWebViewState createState() => _MyWebViewState();
}

class _MyWebViewState extends State<MyWebView> {
  late WebViewController _controller;

  @override
  Widget build(BuildContext context) {
    return WebView(
      initialUrl: 'about:blank',
      javascriptMode: JavascriptMode.unrestricted,
      onWebViewCreated: (WebViewController webViewController) {
        _controller = webViewController;
        _loadHtmlFromAssets();
      },
      javascriptChannels: <JavascriptChannel>{
        _createJavascriptChannel(context),
      },
    );
  }

  void _loadHtmlFromAssets() async {
    String fileText = await DefaultAssetBundle.of(context).loadString('assets/index.html');
    _controller.loadUrl(Uri.dataFromString(fileText, mimeType: 'text/html', encoding: Encoding.getByName('utf-8')).toString());
  }

  JavascriptChannel _createJavascriptChannel(BuildContext context) {
    return JavascriptChannel(
      name: 'FlutterLocalStorage',
      onMessageReceived: (JavascriptMessage message) {
        if (message.message == 'getLocalStorage') {
          _controller.evaluateJavascript('window.localStorage.getItem("key")').then((value) {
            // Do something with the value
            print('Value from localStorage: $value');
          });
        }
      },
    );
  }
}

在这个例子中,index.html文件需要放到项目的assets文件夹中,并包含JavaScript代码来读取localStorage的值,并通过JavascriptChannel将其发送到Flutter中。

assets/index.html示例:

代码语言:javascript
复制
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>LocalStorage Example</title>
</head>
<body>
  <script>
    function sendLocalStorageValue() {
      var value = window.localStorage.getItem("key");
      FlutterLocalStorage.postMessage("getLocalStorage");
    }
  </script>
</body>
</html>

在这个HTML文件中,我们创建了一个简单的JavaScript函数 sendLocalStorageValue,当需要从localStorage获取值时,它将触发一个消息,让Flutter接收。

注意:由于安全原因,WebView中的JavaScript和Flutter之间的通信需要在同一源策略下。如何确保这一点取决于你的WebView设置和加载的HTML内容。上述示例中,在about:blank上加载的HTML内容可以简化这方面的处理。

这样,您就可以在Flutter Webview中通过JavaScriptChannel与localStorage进行交互。如果您需要从Flutter中读取或写入localStorage,可以调整_createJavascriptChannel方法以适应您的需求。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

在 Flutter 中使用 WebView

Flutter 调用,因此并不能内嵌于 Flutter Widget 树中,因此在界面的跳转必须得先释放掉,返回后又要重新初始化,所以显示会有很多限制性; interactive_webview 则是基于...webview_flutter 封装的 Flutter 插件,因此原理特性上基本与官方 WebView 一致的; 在2018年 Flutter 发展初期,官方的 webview_flutter 插件有很多问题...运行效果如下图所示: 这里只是简单介绍 webview 在 Flutter 中的使用,其中的高级特性比如与 JavaScript 交互并没有介绍到,有兴趣的读者可以自行查找资料阅读。 这就结束了吗?...Android 很抱歉,其实到现在我也没找到在 Android 9.0+ 上通过 flutter 的 webview 访问 HTTP 网站的办法,我写在这里也是希望如果我的读者找到了解决方案的话欢迎在评论区留言...我查阅了很多资料,也发现了一个曲线救国的做法,就是检测要访问的网页,如果是 HTTPS 的就利用 WebView 访问,如果是 HTTP 的就调用第三方浏览器访问。 额,这个做法吧,不好评价。

3.5K20
  • 在 WebView 中编译 Web 应用,怎样辨别应用是否使用webview

    在 WebView 中编译 Web 应用 官方文档:https://developer.android.google.cn/guide/webapps/webview 如果您希望在客户端应用中提供 Web...WebView 默认只显示网页。 使用 WebView 非常有用的一种常见情形是,您希望在应用中提供可能需要更新的信息,例如最终用户协议或用户指南。...在 Android 应用中,您 可以创建一个包含 WebView 的 Activity,然后使用它来显示在线托管的文档。...在这种情况下,您可能会发现相比于执行网络请求,然后解析数据并在 Android 布局中呈现数据,在 Android 应用中编译 WebView 以显示包含所有用户数据的网页更加轻松。...您可以改为设计一个专为 Android 设备定制的网页,然后在加载该网页的 Android 应用中实现 WebView。

    9410

    在 Flutter 中探索 StreamBuilderimage

    偶尔,在周期结束之前可能会发出一些值。在 Dart 中,您可以创建一个返回 Stream 的容量,该容量可以在异步进程处于活动状态时发射一些值。...假设您需要根据一个 Stream 的快照在 Flutter 中构造一个小部件,那么有一个名为 StreamBuilder 的小部件。...在这个博客中,我们将探索 Flutter 中的 StreamBuilder。我们还将实现一个演示程序,并向您展示如何在您的 Flutter 应用程序中使用 StreamBuilder。...如果传递的值不为空,那么当 connectionState 在等待时,hasData 属性在任何事件中首先都将为 true StreamBuilder( initialData: 0, //...image Code File: 密码档案: import 'package:flutter/material.dart'; import 'package:flutter_steambuilder_demo

    2.5K00

    Flutter Webview添加Cookie的正确姿势

    场景 h5页面要从cookie里面取数据,所以需要在flutter webview的cookie里面塞一些数据,设置的数据多达十几条;按照网上查的使用方式来设置,通过fiddler抓包发现,只能生效一条...,来来回回试了很多次都只有一条,心态崩了 后来看到cookie设置数据也是类似键值对里面套键值对,灵机一动,变换下后就成功了,记录下正确的写法吧 正确姿势 引入 使用的是flutter官方维护的webview...插件 webview_flutter: ^0.3.22+1 错误示例 这是最坑的一个,widget都都没写全,就写了俩个回调,这么写只会生效一条 WebViewController _controller...cookie,这个是没问题的,和上面的区别就是,这个使用双引号包住单引号,只写了一条的使用也是让人肝痛 setSessionID() async { String sessionID = await LocalStorage.get..., ) 最重要的变化就是每条cookie都要用document.cookie作为key,这是最最最关键的 优化写法 上面的写法是写成一行,写成一行是很致命的操作,让赋值操作会变得很迷惑,优化下 ///webview

    1.8K31

    利用flutter_downloader插件在Flutter中实现文件下载

    接下来我们可以在 Terminal 中输入 flutter packagesget或者点击 IDE 左上角的 Packagesget字样安装依赖。 ?...插件配置 iOS端配置 启用 background mode 想要执行这一步,我们在Xcode中打开该项目的 iOS module,如下图所示: ?...在 AndroidManifest.xml 文件中添加如下代码: <provider android:name="vn.hunghd.flutterdownloader.DownloadedFileProvider...库 import 'package:flutter_downloader/flutter_downloader.dart'; 文档中还提供了其他API,譬如暂停下载、取消下载,这里就不再阐述了,文档已经写的很清楚了...这里方便起见我选择在 initState()函数中初始化下载回调函数和对话框: @override void initState() { super.initState(); // 初始化进度条

    6.3K30

    Android笔记:在原生App中嵌入Flutter

    首先有一个可以运行的原生项目 第一步:新建Flutter module Terminal进入到项目根目录,执行flutter create -t module ‘module名字’例如:flutter...create -t module flutter-native 执行完毕,就会发现项目目录下生成了一个module 第二步:同步Flutter module依赖 进入到新生成的Flutter module...结束之后在.android/Flutter/build/outputs/aar/目录下会生成flutter-debug.aar 第三步:设置JDK版本 在app的build.gradle文件中加入: compileOptions...{ sourceCompatibility 1.8 targetCompatibility 1.8 } 第四步:依赖Flutter module 在settings.gradle中加入 include...在app/build.gradle中 dependencies { …… implementation project(':flutter') } 到此准备过程结束,写代码测试一下,我使用的是

    1.7K40

    UWP 在 WebView 中执行 JavaScript 代码(用于模拟用户输入等)

    UWP 中使用 WebView 时可以在网页中额外执行一些代码。于是你几乎可以在网页上做任何事情,那些你可以在浏览器控制台中做的事情。 本文将介绍做法。...---- 准备环境 在页面(XAML)中放一个 WebView,然后取个名字,比如就叫做 WebView。 监听 NavigationCompleted 事件,然后导航到需要操作的页面。...在 JavaScript 中,eval(string) 函数可计算某个字符串,并执行其中的的 JavaScript 代码。...在计算结束后,会返回一个字符串,就是参数中那个字符串执行完之后的返回值(如果有的话)。...于是意味着你可以通过这种方式拿到输入框中的值: var userId = await WebView.InvokeScriptAsync("eval", new[] { "document.getElementById

    2K30

    在开发中实现点击 WebView 中的图片,调用原生控件放大展示

    现在有很多时候,我们的 App 都进行了混合开发,而最简单,最常用的就是有些网页采用了 WebView 进行展示,这就需要我们了解和懂得如何实现 WebView 和 JS 进行交互。...今天我们就来学习一下,如何点击 WebView 中的网页图片,调用原生控件进行放大展示。 其实实现这种交互非常简单,就是通过 JS 调用原生控件。...设置 WebView 这一步就是将我们写的 html 本地文件放入到 WebView 中。...super.onPageFinished(view, url); //这段js函数的功能就是注册监听,遍历所有的img标签,并添加onClick函数,函数的功能是在图片点击的时候调用本地...JavascriptInterface 就是和 mWebView.addJavascriptInterface(new JavascriptInterface(this), “imagelistner”) 中的

    2.4K50
    领券