当 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 运行呢?比如只是使用地图的部分不加载地图,其它部分保持正常工作

阅读 5.1k
2 个回答

改用 require 如何?

try {
    var BMap = require('BMap');
} catch (ex) {
    // Do something
}

底下增加这个script脚本来处理如何
`<script>

if(!BMap){
    //do something
}

</script>`

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题