一、首先安装vue及脚手架vue-li环境
npm install -g @vue/cli-init
2、创建工程
vue init webpack cesium-len02 -y
3、cesium安装
npm install cesium --save
4、webpack配置
4.1 build/webpack.base.conf.js 文件中添加 Cesium module name
resolve: {
alias: {
cesium: path.resolve(__dirname, '../node_modules/cesium/Source')
}
},
(必须配置如下信息,否则报错Error constructing CesiumWidget)
module: {
unknownContextCritical: false,
unknownContextRegExp: /^.\/.*$/, ...
}
4.2 build/webpack.dev.conf.js 文件中添加 static files 管理
plugins: [
new CopyWebpackPlugin([ { from: path.join('node_modules/cesium/Source', '../Build/Cesium/Workers'), to: 'Workers' } ]), new CopyWebpackPlugin([ { from: path.join('node_modules/cesium/Source', 'Assets'), to: 'Assets' } ]), new CopyWebpackPlugin([ { from: path.join('node_modules/cesium/Source', 'Widgets'), to: 'Widgets' } ]), new webpack.DefinePlugin({ // Define relative base path in cesium for loading assets CESIUM_BASE_URL: JSON.stringify('') })
]
5、App.vue 中输入以下代码
<template>
<div id="app">
<div id="cesiumContainer"></div>
</div>
</template>
<script>
import * as Cesium from 'cesium/Cesium'
import * as widget from 'cesium/Widgets/widgets.css'
export default {
name: 'App',
mounted () {
this.$nextTick(() => {
const viewer = new Cesium.Viewer('cesiumContainer')
console.log('viewer: ', viewer)
})
}
}
</script>
<style>
html,
body {
width: 100%;
height: 100%;
padding: 0;
margin: 0;
}
#app,#cesiumContainer {
font-family: "Avenir", Helvetica, Arial, sans-serif;
width: 100%;
height: 100%;
overflow: hidden;
}
</style>
6.运行
npm run dev