Polymer 3 使用 import 来加载外部 Javascript。例如
import {GoogleCharts} from 'google-charts';
但是,这似乎可行,外部库应该使用导出。
我正在尝试使用 mapbox-gl.js 库。这个库,安装有:
npm install mapbox-gl
似乎没有出口任何东西。
在 HTML5 中,您可以使用 mapbox-gl,如下所示:
<script src="node_modules/mapbox-gl/dist/mapbox-gl.js"></script>
<link href="node_modules/mapbox-gl/dist/mapbox-gl.css" rel="stylesheet" />
<script>
const options = {...}
const map = new mapboxgl.Map(options);
</script>
我尝试使用“导入”来加载 mapbox-gl:
import {mapboxgl} from './node_modules/mapbox-gl/dist/mapbox-gl.js';
import mapboxgl from './node_modules/mapbox-gl/dist/mapbox-gl.js';
这不起作用:
Uncaught SyntaxError: The requested module './node_modules/mapbox-gl/dist/mapbox-gl.js' does not provide an export named 'mapboxgl'
Uncaught SyntaxError: The requested module './node_modules/mapbox-gl/dist/mapbox-gl.js' does not provide an export named 'default'
所以,然后我尝试从模块javascript ( )中将脚本和 css 添加到 document.head <script type="module">..</script>
:
// load external mapbox-gl.js script
const mapboxgljs = document.createElement('script');
mapboxgljs.setAttribute('src', 'node_modules/mapbox-gl/dist/mapbox-gl.js');
document.head.appendChild(mapboxgljs);
// load external mapbox-gl.css
const mapboxcss = document.createElement('link');
mapboxcss.setAttribute('href', 'node_modules/mapbox-gl/dist/mapbox-gl.css');
mapboxcss.setAttribute('rel', 'stylesheet');
document.head.appendChild(mapboxcss);
这似乎也不起作用。如果我尝试按如下方式使用 mapbox:
const map = new mapboxgl.Map(options)
我正进入(状态:
Uncaught ReferenceError: mapboxgl is not defined
编辑:
评论者@Salketer 和@barbsan 为这种库显示了正确的导入语法:
import 'node_modules/mapbox-gl/dist/mapbox-gl.js';
或者
import * as mapboxgl from 'node_modules/mapbox-gl/dist/mapbox-gl.js';
现在两者都导致以下错误消息:
Uncaught TypeError: Cannot set property 'mapboxgl' of undefined
这意味着 mapbox-gl 库现在被加载和解释。但是,mapbox-gl 代码包含以下行:
window.mapboxgl = something;
ES6-module 范围无权访问浏览器的“窗口”对象,因此代码失败。另请参阅是否存在等效于“window”的 es6 模块范围?.
现在,我将 HTML5 <script></script> 和 <link /> 标签(见上文)添加到我的项目的 index.html 中。这可行,但组件和模块的想法是从这些组件和模块内部加载依赖项?