flutter解决 dart:html 只支持 flutter_web 其他平台编译报错 Avoid using web-only libraries outside Flutter web(代码片段
Posted 圆号本昊
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了flutter解决 dart:html 只支持 flutter_web 其他平台编译报错 Avoid using web-only libraries outside Flutter web(代码片段相关的知识,希望对你有一定的参考价值。
# 前言
我们在跨平台项目里 import 'dart:html'
会有警告,大致情况如下,直接编译出 web
没有问题
但是跑 android/ios
就不行了,会在编译阶段 error,效果大致如下:
# 解决
Google
官方的意思是要做区分,我们先看看官方的要求:
那么如何做区分呢?可以参考下面这个方法:
import 'xxx' if (dart.library.html) 'xxx:xxx'
太麻烦了,让我们来点简单的
# 叛逆
毕竟是自己的小项目,写得快必杀都好,我们直接用一个 third_party
解决:
dependencies:
universal_html: ^1.2.1
注意这里的版本必须保持一致,然后我们就可以用这个库里的 html.dart
来代替 dart:html.dart
具体原理感兴趣可以看源码
import 'package:universal_html/html.dart' as html;
然后就跟 dart:html
一样使用啦,但是编译时会报错( null-safety
不安全 )
# 战胜
如果是 Android studio ,需要如下操作:
Run --> Edit Configurations --> Add Additional Run args --> --no-sound-null-safety
给个图片方便大家理解:
如果是 VSCode
或者命令行运行 :
flutter run --no-sound-null-safety
具体可以参考:Cannot run with sound null safety because dependencies don’t support null safety
# 总结
- 成果如下,完美运行:个人官网:hornhuang.github.io
flutter_web
太新了,一个坑接着一个,求个三连呗~
以上是关于flutter解决 dart:html 只支持 flutter_web 其他平台编译报错 Avoid using web-only libraries outside Flutter web(代码片段的主要内容,如果未能解决你的问题,请参考以下文章
使用 dart:HTML 库在 Flutter Web 中选择文件时如何获取 Flutter 中的文件名?
如何导入依赖于 Flutter 平台的 Dart 文件或包?
dart:html 中的 Geolocation.getCurrentPosition 在启用 NNBD 的发布模式下不工作