跳至主要内容

将 Web 内容嵌入到 Flutter Web 应用中

在某些情况下,Flutter Web 应用需要嵌入非 Flutter 渲染的 Web 内容。例如,嵌入 google_maps_flutter 视图(使用 Google 地图 JavaScript SDK)或 video_player(使用标准 video 元素)。

Flutter Web 可以在 Widget 的边界内渲染任意 Web 内容,并且之前提到的示例软件包用于实现的原语可用于所有 Flutter Web 应用。

HtmlElementView

#

HtmlElementView Flutter 组件在布局中预留了一个空间,用于填充任何 HTML 元素。它有两个构造函数

  • HtmlElementView.fromTagName.
  • HtmlElementViewregisterViewFactory

HtmlElementView.fromTagName

#

HtmlElementView.fromTagName 构造函数 通过其 tagName 创建一个 HTML 元素,并提供了一个 onElementCreated 方法,用于在元素注入 DOM 之前对其进行配置。

dart
// Create a `video` tag, and set its `src` and some `style` properties...
HtmlElementView.fromTag('video', onElementCreated: (Object video) {
  video as web.HTMLVideoElement;
  video.src = 'https://interactive-examples.mdn.mozilla.net/media/cc0-videos/flower.mp4';
  video.style.width = '100%';
  video.style.height = '100%';
  // other customizations to the element...
});

要了解与 DOM API 交互的方式,请查看 package:web 中的 HTMLVideoElement

要了解转换为 web.HTMLVideoElement 的视频 Object,请查看 Dart 的 JS 互操作性 文档。

HtmlElementViewregisterViewFactory

#

如果您需要更多控制权来生成注入的 HTML 代码,您可以使用 Flutter 用于实现 fromTagName 构造函数的基元。在这种情况下,为需要添加到应用程序中的每种 HTML 内容类型注册您自己的 HTML 元素工厂。

生成的代码更冗长,并且每个平台视图类型有两个步骤。

  1. 使用 dart:ui_web 提供的 platformViewRegistry.registerViewFactory 注册 HTML 元素工厂。
  2. 在应用程序的小部件树中放置带有所需 viewType 的小部件,使用 HtmlElementView('viewType')

有关此方法的更多详细信息,请查看 HtmlElementView 组件 文档。

package:webview_flutter

#

在 Flutter 应用程序中嵌入完整的 HTML 页面是一个非常常见的特性,Flutter 团队提供了一个插件来实现此功能。