前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【flutter】解决 dart:html 只支持 flutter_web 其他平台编译报错 Avoid using web-only libraries outside Flutter web

【flutter】解决 dart:html 只支持 flutter_web 其他平台编译报错 Avoid using web-only libraries outside Flutter web

作者头像
圆号本昊
发布2021-12-30 17:20:01
6800
发布2021-12-30 17:20:01
举报
文章被收录于专栏:github@hornhuanggithub@hornhuang

前言

我们在跨平台项目里 import 'dart:html' 会有警告,大致情况如下,直接编译出 web 没有问题

但是跑 android/ios 就不行了,会在编译阶段 error,效果大致如下:

解决

Google 官方的意思是要做区分,我们先看看官方的要求:

那么如何做区分呢?可以参考下面这个方法:

代码语言:javascript
复制
import 'xxx' if (dart.library.html) 'xxx:xxx'

太麻烦了,让我们来点简单的

叛逆

毕竟是自己的小项目,写得快必杀都好,我们直接用一个 third_party 解决:

代码语言:javascript
复制
dependencies:
  universal_html: ^1.2.1

注意这里的版本必须保持一致,然后我们就可以用这个库里的 html.dart 来代替 dart:html.dart 具体原理感兴趣可以看源码

代码语言:javascript
复制
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 或者命令行运行 :

代码语言:javascript
复制
flutter run --no-sound-null-safety

具体可以参考:Cannot run with sound null safety because dependencies don’t support null safety

总结

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-09-10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 解决
  • 叛逆
  • 战胜
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档