猿问

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

实际中遇到的问题是地图服务,不是 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 运行呢?比如只是使用地图的部分不加载地图,其它部分保持正常工作


慕哥9229398
浏览 754回答 1
1回答

Smart猫小萌

改用&nbsp;require&nbsp;如何?try {&nbsp; &nbsp; var BMap = require('BMap');} catch (ex) {&nbsp; &nbsp; // Do something}
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答