当 Webpack 引用的 CDN 资源不可用时如何忽略引用的模块呢呢?

2016-07-11 10:04:20 +08:00
 sunjourney

实际中遇到的问题是地图服务,不是 CDN 资源。 在 html 中引入了

<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=token"></script>

在 webpack.base.conf.js 设置了外部资源

externals: {
  "BMap": "BMap"
}

当网络正常时:

import BMap from 'BMap'

工作正常

当断网时控制台报错:

Uncaught ReferenceError: BMap is not defined

不仅报错,还阻止了整个 Web APP 运行。用异步模块解析,只要触发 import xxx from 'BMap' 就跪。 import 又只能放在 top level ,没法 try catch 它。怎么才能当网络无法访问 externals 资源时不影响 Web APP 运行呢?比如只是使用地图的部分不加载地图,其它部分保持正常工作

5652 次点击
所在节点    程序员
3 条回复
chemzqm
2016-07-11 11:24:57 +08:00
去掉 import 和 webpack 相关设置,直接检测 window 对象
sunjourney
2016-07-11 11:38:17 +08:00
@chemzqm 感谢,这是好方法, hack 了这个问题,就是不知道有没有 webpack 内部的解决方案。 google 了很久, webpack 文档相关部分也过了,似乎没有。
chairuosen
2016-07-11 17:04:33 +08:00
@sunjourney require 的时候 try catch 一下喽

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/291625

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX