第一步:构建一个新的vue项目
用脚手架@vue/cli
npm install -g @vue/cli
data:image/s3,"s3://crabby-images/7051e/7051e8c155eeb89638a029f2fa44b4dd5276fd24" alt=""
创建项目,ESLint可以先不用,有点碍事
vue init webpack vue-openlayers
data:image/s3,"s3://crabby-images/8d224/8d22408348651d625bd82f4cac227b64ae469f81" alt=""
?用开发工具打开项目,跑起来看看有没有问题
npm install
npm run dev
data:image/s3,"s3://crabby-images/5126e/5126e12bdd7cdd8b37d03b49fbd30a1270077a08" alt=""
?data:image/s3,"s3://crabby-images/afe4f/afe4f8e07948770ce835db01a48d14af188e3327" alt=""
data:image/s3,"s3://crabby-images/d4ea0/d4ea0707a042a2bf56a254fcc4ef45d4f1da50d7" alt=""
?第二步:安装ol
npm install ol
data:image/s3,"s3://crabby-images/29014/29014308175b2ef1667a6f12dc9f900f32fd9485" alt=""
?第三步:创建地图组件mapView
<template>
<div id="mapDiv"></div>
</template>
<script>
import "ol/ol.css";
import {Map, View} from "ol";
import TileLayer from "ol/layer/Tile";
import OSM from "ol/source/OSM";
export default {
data() {
return {
map: null
};
},
mounted() {
new Map({
target: "mapDiv",
layers: [new TileLayer({
// 使用OSM地图
source: new OSM()
})],
view: new View({
// 使用WGS84坐标系
projection: "EPSG:4326",
// 定位杭州
center: [120.216224, 30.252737],
// 放大十倍
zoom: 10
})
});
}
};
</script>
<style scoped>
#mapDiv {
width: 100%;
height: 100%;
}
</style>
第四步:在router中引入组件
data:image/s3,"s3://crabby-images/abaf9/abaf91b26dd66d56a73a4b1a0613b251a033ee2b" alt=""
?第五步:在App.vue中改一下布局参数,让地图显示出来,sytle中加上高度
<style>
html,body{
height: 100%;
}
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
height: 100%;
}
</style>
第六步:运行
data:image/s3,"s3://crabby-images/01e76/01e76b665290ff789533061fb519b19cf2ff5eb0" alt=""
源码地址:
vue-openlayers: openlayers学习 https://gitee.com/tang_workhome/vue-openlayers.git
|