ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2021-09-10 21:01:33  阅读:317  来源: 互联网

标签:web -- dart html 报错 safety null flutter


# 前言

我们在跨平台项目里 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

# 总结

标签:web,--,dart,html,报错,safety,null,flutter
来源: https://blog.csdn.net/qq_43377749/article/details/120229314

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有