运行 build_runner
需要将你的 Dart SDK 升级到 2.0 版本以上。
如果你有使用 build_runner
方面的问题,请参阅下面的 故障排除 章节。
将 build_runner
作为开发服务器使用
-
编辑 package 中的 pubspec.yaml 文件,添加
build_runner
和build_web_compilers
作为 dev dependencies:dev_dependencies: build_runner: ^2.0.0 build_web_compilers: ^3.0.0
-
拉取依赖:
pub get
-
启动服务器
pub run build_runner serve
serve
命令运行期间,每次对文件的修改都会触发重新构建。
初次构建耗时较长,之后由于是增量构建,所以会更快。
创建输出目录
参数 --output <directory name>
用于指定构建的输出路径。该参数可配合 build
、watch
和 serve
命令使用。路径可以是一个本地路径,也可以是远程服务器地址。
如果要部分输出,比如说只输出 web
目录,可以使用参数 --output web:<directory name>
。
其他 build_runner
命令
- build: 单独运行 build 命令。如果要输出文件到源码目录下,那么这个命令会非常有用。结合
--output <dirname>
可将源码和生成的资源合并输出。 - watch: 和
build
类似,不同的是它可以监控文件的变化。结合--output <dirname>
使用,可以保证合并输出路径下的资源是最新的。 - test: 创建输出目录,同时运行
pub run test
。这个命令需要使用build_test
作为 dev dependencies。
切换至 dart2js
缺省情况下 build_web_compilers
调用 dartdevc 进行编译。如果要切换到 dart2js,需要在运行 pub run build_runner build
(或 serve
)时携带 --release
参数。如果要传递一些参数到 dart2js 的话,可以通过创建 build.yaml
文件来实现。
targets:
$default:
builders:
build_web_compilers:entrypoint:
options:
dart2js_args:
- --minify
- --fast-startup
故障排除
编译时长诊断
参见 https://github.com/dart-lang/build/blob/master/docs/measuring_performance.md。
没有匹配的 build_runner 版本
-
确保你的 Dart SDK 版本为 2.0 以上。
dart --version
-
检查项目依赖的 package 的 Dart SDK 版本,确保也在 2.0 以上。
打开文件过多
如果提示 the directory listing failed due to too many open files,表示你的操作系统对此有限制。详情参阅https://github.com/dart-lang/build/issues/857
网友评论