gpt4 book ai didi

javascript - 在 Flutter Webview 中运行一些 Javascript 文件,例如 index.js

转载 作者:IT老高 更新时间:2023-10-28 12:41:46 27 4
gpt4 key购买 nike

如何在 flutter_webview_plugin 中运行 Javascript 文件。我用这个试试。

flutterWebViewPlugin.evalJavascript("require('./index.js');");

但是什么也没发生。

当我尝试运行 flutter 代码时,它什么也没显示

我的 index.Js 文件包含一个简单的警报语句

alert('hello world');

最佳答案

首先,您使用了“require”功能。此功能未在 javascript 本身中实现。 it's a part of NodeJs .所以该功能将不起作用。

为了将 js 文件加载到 Flutter 中,您应该将其视为文本文件并正确加载。因此,您需要将文件添加到 assets 文件夹,添加到 pubspec 文件中,然后加载它。 read the full answer here

第二,你使用了evalJavascript。此功能可用于许多不同的情况。但只有当你有一个 View 面板时它才会起作用。

查看以下示例:

import 'dart:io';

import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_webview_plugin/flutter_webview_plugin.dart';

main() async {
String jsCode = await rootBundle.loadString('assets/javascript.js');

runApp(new MaterialApp(
home: LunchWebView(jsCode),
));
}

class LunchWebView extends StatelessWidget {
final String text;
LunchWebView(this.text);

@override
Widget build(BuildContext context) {
final FlutterWebviewPlugin flutterWebviewPlugin = FlutterWebviewPlugin();
flutterWebviewPlugin.launch('https://www.google.com');
flutterWebviewPlugin.evalJavascript(text);
return Container();
}
}

注意::我没有处理重新加载和其他异常。您应该检查是否有任何 webview 对象打开,然后调用午餐方法。

关于javascript - 在 Flutter Webview 中运行一些 Javascript 文件,例如 index.js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56256509/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com