58fair在flutter3.7.0以上版本fair_compiler不生成逻辑js文件问题

如果遇到dart 转js逻辑文件无法生成,抛出异常,这可能是因为flutter升级到3.7.0以上版本, fair的dart2js库转化异常了。

  • flutter 3.0.x dart 2.17
  • flutter 3.3.x dart 2.18
  • flutter 3.7.x dart 2.19
  • flutter 3.10.x dart 3.0

错误日志

image.png

问题分析

分析一下 生成过程中库依赖关系:

name: carrier_project_name
description: A new Flutter project.


publish_to: 'none' # Remove this line if you wish to publish to pub.dev

version: 1.0.0+1

environment:
  sdk: ">=2.12.0 <3.0.0"


dependencies:
  flutter:
    sdk: flutter

  fair:
    git:
      url: https://github.com/wuba/fair.git
      ref: main
      path: fair

  fair_pushy:
    git:
      url: https://github.com/wuba/FairPushy.git
      ref: main
      path: sdk

  flutter_staggered_grid_view: ^0.6.2
  fluttertoast:

  cupertino_icons: ^1.0.2

dev_dependencies:
  flutter_test:
    sdk: flutter

  build_runner: ^2.1.2
  fair_compiler: any




flutter:
  uses-material-design: true
  assets:
    - assets/
    - assets/fair/
    - assets/plugin/
    - assets/image/

flutter build 命令

flutter packages pub run build_runner build --delete-conflicting-outputs

主要是通过工程目录dev_dependencies:下面配置的库,进行build构建的。

那么我们看到fair需要添加 两个工具,一个就是系统的build_runner 另一个就是 fair实现的自动化构建库 fair_compiler 库

  build_runner: ^2.1.2
  fair_compiler:

通过使用 fair_compiler 库的接入,对工程中dart代码扫描,对于添加了@FairPatch @FairProp等注解的代码自动生成 fair 逻辑文件js文件、界面文件json文件。

分析一下 fair_compiler 的整个库依赖关系:

fair除了热更新fair_pushy 这里不讨论。其他几个配套的工具全都在一个项目中
官方地址:fair

  • 1、fair_compiler

在fair 项目中 fair_compiler 子目录下配置如下:

dependencies:




  analyzer: ^5.5.0



  dart_style: ^2.0.0

  fair_annotation: ^2.3.0

  fair_dart2dsl: ^1.3.2

  fair_dart2js: ^1.4.0

  • 2、fair_dart2dsl

在 dart2dsl 目录下:

dependencies:




  analyzer: ^5.5.0



  • 3、fair_dart2js
    在 dart2js 目录下:
dependencies:




  analyzer: ^5.5.0



  • 4、dart_style

dart_style

dart_style 2.3.2

 dependencies:
  analyzer: '>=5.12.0 <7.0.0'
  • 5、analyzer

analyzer

analyzer-5.13.0

dependencies:




  collection: ^1.17.0

dart2js库调试

dart2js 单个文件测试:

image.png

修改 analyzer 版本

尝试修改 analyzer版本,修改为历史版本,发现: analyzer 5.6.0 没问题,analyzer 5.13.0 报错

回到接入fair的fair化项目工程

我们看下fair_compiler 依赖情况如下:

dependencies:




  analyzer: ^5.5.0



  dart_style: ^2.0.0

  fair_annotation: ^2.3.0

  fair_dart2dsl: ^1.3.2

  fair_dart2js: ^1.4.0

dart_style 2.3.2

dependencies:
  analyzer: '>=5.12.0 <7.0.0'

当 dart_style 2.3.2 analyzer 将自动被升级到对应版本5.12版本以上。

fair_compiler 依赖 dart_style

dart_style 和 dart2js都依赖 analyzer

如果仅设置 analyzer 5.6.0,dart_style 2.3.2 会报错,从dart_style历史版本看 dart_style2.3.0开始就适配flutter3.7&dart2.19并且要求analyzer5.7版本以上。
往前找最新的版本是2.2.5 ,这个版本支持到dart2.17&flutter3.0+

  • flutter 3.0.x dart 2.17
  • flutter 3.3.x dart 2.18
  • flutter 3.7.x dart 2.19
  • flutter 3.10.x dart 3.0

升级到3.7.0以上 flutter

dart2dsl 库依赖的 dart_style 变成了最新版本 2.3.2 版本 (flutter3.7和flutter3.10都是这个版本)
dart_style 依赖的 analyzer 也变成了新版本 (flutter3.7 为5.13.0,flutter3.10为6.1.0)

对于3.7.0以上版本flutter 需要手动设置dependency_overrides,避免被升级:
analyzer: 5.6.0
dart_style: 2.2.5

结论:

  • 修改dependency_overrides为 analyzer和dart_style指定版本,可以解决flutter3.7和3.10版本问题
dependency_overrides:



  # 如果你是 3.3.0 以下的版本,需要 override collection
  collection: 1.17.0

  # 如果是3.7.0 以上的版本,需要固定dart_style 和analyzer版本避免自动升级,因为dart2.19以上版本有问题,dart2js库转换异常
  analyzer: 5.6.0
  dart_style: 2.2.5



再次运行。成功:

image.png

所有dart需要的目标js文件的都转化成功了:

image.png

  • 但是对于fair项目例子中下拉刷新功能的例子JRList.dart 在所运行的3.7和3.10,3.0.5的这几个版本的测试中,仍然是页面报错不支持下拉刷新。

© 版权声明
THE END
喜欢就支持一下吧
点赞0

Warning: mysqli_query(): (HY000/3): Error writing file '/tmp/MYPcyYuw' (Errcode: 28 - No space left on device) in /www/wwwroot/583.cn/wp-includes/class-wpdb.php on line 2345
admin的头像-五八三
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

图形验证码
取消
昵称代码图片