Flutter网页视图与页面调用插件webview_flutter_pagecall_poc的使用

在Flutter应用中,嵌入网页是非常常见的需求。webview_flutter 插件提供了强大的功能来实现这一需求,并且可以通过 webview_flutter_pagecall_poc 插件实现网页与Flutter页面之间的双向通信。


1. 引入依赖

首先,在 pubspec.yaml 文件中添加 webview_flutterwebview_flutter_pagecall_poc 的依赖:

dependencies:
  flutter:
    sdk: flutter
  webview_flutter: ^4.0.0
  webview_flutter_pagecall_poc: ^1.0.0

然后运行 flutter pub get 来安装这些依赖。


2. 配置 Android 和 iOS

Android

确保 minSdkVersion 至少为 19:

android {
    defaultConfig {
        minSdkVersion 19
    }
}

iOS

确保 Xcode 版本支持 WKWebView(通常 Xcode 10 及以上)。


3. 基本使用示例

以下是一个完整的示例代码,展示如何使用 webview_flutterwebview_flutter_pagecall_poc 插件:

// 导入必要的库
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
import 'package:webview_flutter_pagecall_poc/webview_flutter_pagecall_poc.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: WebViewPage(),
    );
  }
}

class WebViewPage extends StatefulWidget {
  @override
  _WebViewPageState createState() => _WebViewPageState();
}

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

  @override
  void initState() {
    super.initState();

    // 初始化 WebView 控制器
    _controller = WebViewController()
      ..setJavaScriptMode(JavaScriptMode.unrestricted)
      ..setNavigationDelegate(NavigationDelegate(
        onProgress: (int progress) {
          print('Loading progress: $progress%');
        },
        onPageStarted: (String url) {
          print('Page started loading: $url');
        },
        onPageFinished: (String url) {
          print('Page finished loading: $url');
        },
      ))
      ..loadRequest(Uri.parse('https://example.com'));

    // 添加 PageCall 支持
    _controller.addPageCallHandler((message) {
      print('Received message from web: $message');
      return 'Response from Flutter';
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('WebView with PageCall'),
      ),
      body: WebViewWidget(controller: _controller),
    );
  }
}

4. 关键功能说明

4.1 加载网页

通过 WebViewController.loadRequest() 方法加载指定的 URL 或本地文件。

_controller.loadRequest(Uri.parse('https://example.com'));

4.2 设置 JavaScript 模式

允许或禁止执行 JavaScript:

_controller.setJavaScriptMode(JavaScriptMode.unrestricted);

4.3 页面导航拦截

通过 NavigationDelegate 拦截页面跳转请求:

_navigationDelegate: NavigationDelegate(
  onNavigationRequest: (NavigationRequest request) {
    if (request.url.startsWith('https://youtube.com')) {
      return NavigationDecision.prevent; // 阻止跳转到 YouTube
    }
    return NavigationDecision.navigate; // 允许其他跳转
  },
),

4.4 双向通信(PageCall)

使用 addPageCallHandler 注册一个处理函数,用于接收来自网页的消息并返回响应。

_controller.addPageCallHandler((message) {
  print('Received message from web: $message');
  return 'Response from Flutter';
});

在网页端可以调用以下 JavaScript 代码发送消息:

window.flutter_inappwebview.callHandler('pageCallHandler', 'Hello from web!');

5. 完整 Demo 效果

运行上述代码后,您将看到一个带有 WebView 的页面,能够加载指定的网页并支持从网页向 Flutter 传递消息。同时,您可以点击按钮触发 Flutter 向网页发送响应。


6. 注意事项

  1. 权限设置:确保您的 AndroidManifest.xml 文件中包含网络访问权限:

    <uses-permission android:name="android.permission.INTERNET"/>
  2. 调试模式:在 Android 上启用 WebView 调试功能(可选):

    AndroidWebViewController.enableDebugging(true);
1 回复

更多关于Flutter网页视图与页面调用插件webview_flutter_pagecall_poc的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


在Flutter中,webview_flutter 是一个常用的插件,用于在应用中嵌入网页视图。而 webview_flutter_pagecall_poc 是一个基于 webview_flutter 的插件,用于在网页视图和Flutter页面之间进行通信和调用。

1. 添加依赖

首先,你需要在 pubspec.yaml 文件中添加 webview_flutterwebview_flutter_pagecall_poc 的依赖:

dependencies:
  flutter:
    sdk: flutter
  webview_flutter: ^4.0.0
  webview_flutter_pagecall_poc: ^1.0.0

然后运行 flutter pub get 来获取依赖。

2. 基本使用

以下是一个简单的示例,展示如何使用 webview_flutter_pagecall_poc 插件在Flutter中嵌入网页视图,并在网页和Flutter之间进行通信。

import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
import 'package:webview_flutter_pagecall_poc/webview_flutter_pagecall_poc.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: WebViewExample(),
    );
  }
}

class WebViewExample extends StatefulWidget {
  @override
  _WebViewExampleState createState() => _WebViewExampleState();
}

class _WebViewExampleState extends State<WebViewExample> {
  late WebViewController _controller;
  late PageCallHandler _pageCallHandler;

  @override
  void initState() {
    super.initState();
    _pageCallHandler = PageCallHandler(
      onPageCall: (String method, dynamic arguments) async {
        // 处理从网页调用的方法
        if (method == 'showMessage') {
          ScaffoldMessenger.of(context).showSnackBar(
            SnackBar(content: Text('Message from Web: $arguments')),
          );
        }
        return null;
      },
    );
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('WebView PageCall POC'),
      ),
      body: WebView(
        initialUrl: 'https://your-webpage.com',
        javascriptMode: JavascriptMode.unrestricted,
        onWebViewCreated: (WebViewController webViewController) {
          _controller = webViewController;
          _pageCallHandler.attachToWebView(_controller);
        },
        javascriptChannels: <JavascriptChannel>{
          _pageCallHandler.javascriptChannel,
        },
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () async {
          // 调用网页中的JavaScript方法
          await _controller.evaluateJavascript('callFromFlutter("Hello from Flutter!")');
        },
        child: Icon(Icons.send),
      ),
    );
  }
}

3. 解释代码

  • WebView: 使用 webview_flutter 插件嵌入网页视图。
  • PageCallHandler: 使用 webview_flutter_pagecall_poc 插件处理网页和Flutter之间的通信。
  • onPageCall: 当网页调用Flutter方法时,会触发此回调。你可以在这里处理来自网页的调用。
  • javascriptChannels: 将 PageCallHandlerJavascriptChannel 添加到 WebView 中,以便网页可以调用Flutter方法。
  • evaluateJavascript: 在Flutter中调用网页中的JavaScript方法。

4. 网页端代码

在网页中,你可以使用以下代码来调用Flutter方法:

function callFromFlutter(message) {
  console.log('Received from Flutter:', message);
}

// 调用Flutter方法
window.flutter_inappwebview.callHandler('showMessage', 'Hello from Web!');
回到顶部
AI 助手
你好,我是IT营的 AI 助手
您可以尝试点击下方的快捷入口开启体验!