【译】10 款质量最佳最受欢迎的 Flutter 工具库

3,139 阅读5分钟

由作者供图

Flutter 是谷歌为实现一套代码编译至移动端、web 端及桌面端应用而推出的一套 UI 开发框架。

Flutter 是基于 Dart 编程语言来做开发的,同时 Flutter 的开放社区——Dart.dev也非常活跃,官方也在社区上提供技术支持,并且已经有大量的第三方工具包可供使用,这一切使得 Flutter 开发框架具有非常高的生产力。

这篇文章将列举最热门口碑最佳的 10 个 Flutter 工具库,以此来展示 Flutter 作为一种新型的软件开发平台的成熟程度。

如果你还没有使用过 Flutter,不妨先读一读我发布在 medium 上的这篇文章,可以学会如何最快速地使用你自己喜欢的 Flutter 工具库。

1. HTTP

仓库地址:pub.dev/packages/ht…

支持平台:iOS、Android、Web

如今,所有的内容都基于网络,因此一款功能强大的 HTTP 请求库必不可少。这个工具库由 Dart 团队开发并还在积极维护着,其包含一系列的操作 HTTP 请求的高级函数和类。这个工具库始于 2012 年,绝对是非常靠谱的。

此工具库提供的用于操作 HTTP 请求的高级函数用法实例:

import 'package:http/http.dart' as http;

# POST请求
var url = 'https://example.com/whatsit/create';
var data = {'name': 'Jack', 'age': 38};

var response = await http.post(url, body: data);

print('Response status: ${response.statusCode}');
print('Response body: ${response.body}');

# GET请求
print(await http.read('https://example.com/foobar.txt'));

2. flutter_slidable

仓库地址:pub.dev/packages/fl…

支持平台:iOS、Android、Web

flutter_slidable 用法示例 (查看源码)

用就非常广泛,足以说明其对用户操作便利性的帮助之大。

这个插件自带有很多开箱即用的特性,同时这不限制开发者对其进行个性化的定制,以下是其主要特性:

  • 接受primary(左/上)和secondary(右/下)窗口小部件列表作为操作列表
  • 滑动状态可以取消
  • 内建有四个操作按钮位
  • 内建有两个滑动部件
  • 内置滑动动画
  • 轻松创建自定义布局与动画
  • 点击操作按钮后自动关闭滑动状态(可被重写)
  • 最近的“Scrollable”开始滚动时关闭(可被重写)
  • 可通过配置关闭左右滑动特性

3. Shared Preferences

仓库地址: pub.dev/packages/sh…

支持平台: iOS, Android, Web, Linux

这个库将对个系统平台的持久缓存库进行了包装,一般用来存储像用户设置这样的简单数据,其在各个系统平台的原生实现如下:

  • iOS 和 macOS 采用 NSUserDefaults 实现
  • Android 采用 SharedPreferences实现
  • Web 环境采用 LocalStorage 实现
  • Linux 环境下使用一个本地的 JSON 文件来存储

这个库一般情况下会异步将数据做本地持久缓存,但无法保证一定100%缓存成功,因此其一般用于存储那些非关键性的数据,对于 APP 中关键数据请采用下面介绍的 sqflite 来实现。

4. sqflite

仓库地址:pub.dev/packages/sq…

支持平台:iOS、Android、MacOS

这是一个 Flutter 版的 SQLite 插件,同时支持 iOS、Android、MacOS 系统。值得注意的是因为 web 端没有基于 SQL 的数据存储实现,这个库是不支持在 web 端使用的。以下是它的一些特性:

  • 支持事务和批处理
  • 自动进行版本管理
  • 提供了 CRUD 工具函数
  • 在 Android 和 iOS 环境下数据库操作是在后台独立线程进行避免了 UI 线程阻塞

如果你期望的不仅仅是 shared_preferences 库能提供的基本数据存储功能,可以不用深入研究这个库了。

5. url_launcher

仓库地址:pub.dev/packages/ur…

支持平台:iOS、Android、Web

这个插件可以帮你快速打开一个 URL,URL 地址可以是以下几个类型之一:

  • HTTP:例如 http://example.orghttps://example.org
  • 邮箱:mailto:<e-mail 地址>
  • 拨打电话:tel:<phone 手机号>
  • SMS 短信:sms:<phone 手机号>

基本使用非常简单,如下示例:

const url = 'https://flutter.dev';

if (await canLaunch(url)) {
  await launch(url);
} else {
  throw 'Could not launch $url';
}

6. video_player

仓库地址:pub.dev/packages/vi…

支持平台:iOS、Android、Web

图片和示例视频来自pub.dev

这个库支持多种视频格式播放,其能否完美支持各种视频格式取决于应用程序最终运行时所在的系统平台。例如,iOS 和 Android 系统背后所依赖的库是不一样,其视频格式支持程度也不相同。同样的,在 web 端这个库所支持的视频格式取决于用户所使用的的浏览器。

虽然这个库叫做 video_player,但是它也是支持音频播放的。另外这个库已经相当成熟,其 API 已经足够稳定,因此这个库也可以作为音频播放器的替代者。

这个库同时支持本地文件和远程服务器文件的播放,示例代码可以参考这个

7. crypto

仓库地址:pub.dev/packages/cr…

支持平台:所有平台

这是使用纯 Dart 语言开发的一套实现哈希加密的函数,这也意味着这个库可以独立使用不依赖于额外的第三方库。

这个库支持的加密算法如下:

  • SHA-1
  • SHA-224
  • SHA-256
  • SHA-384
  • SHA-512
  • MD5
  • HMAC (例如:HMAC-MD5, HMAC-SHA1, HMAC-SHA256)

由于这是一个单纯的加密算法库并非 GUI 工具库,因此其支持全部平台。

8. carousel_slider

仓库地址:pub.dev/packages/ca…

支持平台:iOS、Android、Web

轮播示例图来自 pub.dev

轮播图在各个 APP 和网站中非常常见,这个轮播图插件库提供了出色的可定制的轮播插件,同时支持了多个平台。

这个插件接受 widget 部件作为轮播的内容项,因此一切可以作为 widget 部件模块都可以作为轮播插件的轮播项。

这个网站是使用 Flutter 开发的 web 端网站,使用了此插件实现了一些轮播效果的 demo,可以点击查看。

以下是在 APP 开发中使用此插件的示例:

CarouselSlider(
  options: CarouselOptions(height: 400.0),
  items: [1,2,3,4,5].map((i) {
    return Builder(
      builder: (BuildContext context) {
        return Container(
          width: MediaQuery.of(context).size.width,
          margin: EdgeInsets.symmetric(horizontal: 5.0),
          decoration: BoxDecoration(
            color: Colors.amber
          ),
          child: Text('text $i', style: TextStyle(fontSize: 16.0),)
        );
      },
    );
  }).toList(),
)

此插件有非常多的可配置参数,例如:

  • 高度和宽高比
  • 支持无限滚动
  • 反转滚动方向
  • 支持自动开始滚动,支持配置滚动间隔,支持滚动动画持续时间
  • 支持配置滚动方向为:水平或垂直

9. path

仓库地址:pub.dev/packages/pa…

支持平台:iOS、Android、Web

路径处理既简单又异常复杂,因为在不同系统平台处理方式有所不同。要保证不引入 bug 和安全漏洞,通常需要使用路径解析库来专门处理路径。使用这个库可以非常方便的拼接路径、文件名及当前系统对应的分隔符,示例如下:

import 'package:path/path.dart' as p;
p.join('directory', 'file.txt');

10. location

仓库地址:pub.dev/packages/lo…

支持平台:iOS、Android、Web、MacOS

手机的一大优点是它的便携性与精确定位能力相结合,这一能力已经为我们创造了非常多的应用。这款location定位插件使得定位用户当前位置变得更新简单轻松。它既支持监听用户定位改变的回调,又提供了 API 接口以便在适当时机向系统申请用户地址访问权限。

 Flutter 应用中使用 location 插件示例图片 (访问源码)


以上是我推荐的 10 款最受欢迎的 Flutter 工具库,如果你有更好的 Flutter 工具库推荐,欢迎在底下评论区留言!

如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。


掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 AndroidiOS前端后端区块链产品设计人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划官方微博知乎专栏