本来想讲完flutter所有组件的,但是现在这类文章将的很多。所以就不将这些了 以后就从flutter工程化开讲
包括以下内容:
- 编写flutter常用脚本
- 搭建自己的组件库
- 教你搭建企业级flutter开发框架
- flutter常用技巧
包管理
实际项目中我们会用到许多package,无论是我们自己编写的还是使用的第三方。寻找我们需要的包国内可以在https://pub.flutter-io.cn
查找。
使用包
flutter的package使用和npm包类似。添加一个package的步骤如下:
- 打开应用文件夹下的 pubspec.yaml 文件,然后在 pubspec.yaml 下添加包,如css_colors.
- 在命令行中运行:flutter pub get或者在 Android Studio/IntelliJ 中点击 pubspec.yaml 文件顶部操作功能区的 Packages get,在 VS Code 中点击位于 pubspec.yaml 文件顶部操作功能区右侧的 Get Packages
- 在 Dart 代码中添加相关的 import 语句。
- 如果 package 内有特定平台的代码(Android 的 Java/Kotlin, iOS 的 Swift/Objective-C)
package版本
指定package的版本,flutter给我们提供了多种方法,如指定版本范围:
代码语言:javascript复制dependencies:
url_launcher: ^5.4.0 # caret语法, 任何 5.4.x版本都可以.
image_picker: '5.4.3' # 指定版本.
url_launcher: '>=5.4.0 <6.0.0' # 指定一个最小和最大的版本号
plugin1:
path: ../plugin1/ #指定本地路径
dependencies:
package1:
git:
url: git://github.com/flutter/packages.git
path: packages/package1 # pub 工具会默认假定 package 位于 Git 仓库的根目录。如果不是这种情况,你可以使用 path 参数指定位置
ref: v1.3.2 # 使用tag指定版本
如果两个包声明了不兼容的 url_launcher 版本,它们实际上仍可能以兼容的方式使用 url_launcher。在这种情况下,可在 pubspec.yaml 文件中添加一个依赖覆盖声明来强制使用特定版本,从而处理冲突。
代码语言:javascript复制dependencies:
some_package:
another_package:
dependency_overrides:
url_launcher: '5.4.0'
实际项目中如何运用
在实际项目中,通常我们都使用固定版本,避免版本升级带来未知的问题。所以可以使用脚本来检查我们的版本使用是否符合规范
代码语言:javascript复制#!/bin/bash
egrep -r --include="pubspec.yaml" --exclude-dir={ios,android} "^" -n . > non_fixed_packages.log
FAILED=`[[ -s non_fixed_packages.log ]] && echo 1 || echo 0`
if [ "$FAILED" -eq "1" ]; then
echo "#########################################################################################"
echo "Please remove the ^ from the package version(s) in the file(s) to use fixed version(s)"
echo "#########################################################################################"
cat non_fixed_packages.log
fi
rm non_fixed_packages.log
exit $FAILED