编写最佳 Flutter 代码 :NetworkImage 与 Image.network 以及何时使用它们

我在许多 flutter 代码库中注意到的最常见错误之一是在屏幕上显示图像(尤其是在尝试显示网络图像时)。有些人设法让它工作,但不知道它为什么起作用,甚至不知道为什么他们应该使用什么,因此,这就是本文的原因。

显示图像是大多数移动应用程序的基础。 Flutter 提供了一个 Image 小部件来处理不同类型的图像。在 Flutter 中,我们可以通过以下任一方式在屏幕上显示图像:

  1. 创建一个 ImageProvider 并将其传递给 Image 小部件或
  2. 将图像 url 直接传递给图像小部件

创建一个 ImageProvider 并将其传递给 Image 小部件

下面是 Flutter 中 Image 类的默认构造函数的示例代码片段。

dart 复制代码
Image(
  image: YOUR_IMAGE_PROVIDER
)

这里,Image 类需要一个 ImageProvider 类型的图像属性,在这里传递任何其他类型都会导致应用程序崩溃。根据图像的位置,有多种创建 ImageProvider 对象的方法。下面是常见的 ImageProvider 列表;

  • AssetImage,用于从 assets 创建 ImageProvider 对象
  • NetworkImage,用于从网络创建 ImageProvider 对象
  • MemoryImage,用于从 Uint8List 创建 ImageProvider 对象

使用这些类中的任何一个创建 ImageProvider 对象都非常简单,并且它们都遵循相同的模式。请参阅下面的代码片段。

dart 复制代码
NetworkImage(
  "https://example.com/image.jpg",
  width: 100,
  height: 100,
)

请注意,这些 ImageProvider 本身无法在屏幕上显示图像,因为它们不是小部件,它们需要小部件的帮助才能做到这一点,因此需要 Image 小部件,例如到目前为止两个代码片段的组合应该是能够在屏幕上显示图像。

dart 复制代码
Image(
  image: NetworkImage(
      "https://example.com/image.jpg",
      width: 100,
      height: 100,
    )
  )

将图像 url 直接传递给 Image 小部件

这非常简单,因为除了图像网址之外,它不依赖于任何其他东西,例如

dart 复制代码
Image.network(your_imageg_url)

这里需要注意两件事:首先,这会返回一个小部件,因此可用于在屏幕上显示图像。其次,这也是 Image 小部件类的命名构造函数。其他可用于在屏幕上显示图像的命名 Image 类构造函数包括:

  • Image.asset,用于使用 key 从 AssetBundle 获取图像
  • Image.file,用于从文件中获取图像。
  • Image.memory,用于从 Uint8List 获取图像。

因此,单独使用它们就可以在屏幕上显示图像。

NetworkImage 和 Image.network 之间的区别

NetworkImageImage.network 的主要区别在于它们提供的输出类型,这反过来又影响了它们的使用方式。就像 Image.network 创建了一个部件一样,NetworkImage 创建了 ImageProvider,它依赖于图像类或任何需要 Imageprovider 才能在屏幕上显示图像的小部件。

话虽如此,在需要 ImageProvider 并且需要从网络加载图像的地方使用 NetworkImage。需要 imageProvider 的常见地方包括 FadedInImage、背景(例如容器、圆形头像)等,

dart 复制代码
Container(
  child: FadedInImage(
    placeholder: AssetImage('assets/placeholder.png'),
    image: NetworkImage('https://example.com/image.jpg'),
    fadeInDuration: Duration(milliseconds: 300),
  ),
)

当您只想在屏幕上输出图像时,请使用 Image.network


原文:medium.com/@xrolediamo...

相关推荐
Momoly081 分钟前
vue3+el-table 利用插槽自定义数据样式
前端·javascript·vue.js
唯有选择2 分钟前
让你的应用界面好看的基石:Flutter主题Theme使用和扩展自定义字段
前端·flutter
山有木兮木有枝_2 分钟前
告别布局间隙:浮动(float)在网页排版中的高阶应用
前端
满分观察网友z3 分钟前
vue的<router-link>的to里面的query和params的区别
前端
小约翰仓鼠4 分钟前
vue3表格使用Switch 开关
前端·javascript·vue.js
JiangJiang6 分钟前
🔥 面试官:Webpack 为什么能热更新?你真讲得清吗?
前端·面试·webpack
anyup25 分钟前
快崩溃了!华为应用商店已经 4 次驳回我的应用上线
前端·华为·uni-app
Qian Xiaoo39 分钟前
前后端分离开发 和 前端工程化
前端
要加油哦~1 小时前
vue · 插槽 | $slots:访问所有命名插槽内容 | 插槽的使用:子组件和父组件如何书写?
java·前端·javascript
先做个垃圾出来………1 小时前
split方法
前端