vue3+openlayers项目初始化

说明:vue3+vite+cesium项目环境搭建参考上一篇文章:juejin.cn/post/754836...

1、引入ol,创建地图容器

xml 复制代码
<template>     
    <div id="mapBox"></div> 
</template>

2、地图渲染方法

typescript 复制代码
//baseMap.ts 
import { Map, View } from 'ol'; 
import TileLayer from 'ol/layer/Tile'; 
import * as olProj from 'ol/proj'; 
import OSM from 'ol/source/OSM'; 
const initCenter = [114.5, 38]; 
let map: any; 
const initMap = (mapId: string) => {   
    let center = olProj.fromLonLat(initCenter);   
    let layer = new TileLayer({     
        source: new OSM(),   
    })   
    map = new Map({     
        layers: [layer],     
        target: mapId,     
        view: new View({       
            center: center,       
            zoom: 4,       
            maxZoom:20     
        })   
    }) 
}; 
export {   
    initMap 
}

3、实现效果

4、可能出现错误处理

1)引入.ts文件报错:An import path cannot end with a '.ts' extension. Consider importing '../components/BaseMap.js' instead.

这个是由于使用了 别名 alias 导致的。以 tsconfig.json 的拓展形式兼容配置

json 复制代码
//在tsconfig.json 文件中加入这一句 
"extends": "./tsconfig.extends.json"

在根目录下创建tsconfig.extends.json文件

json 复制代码
//tsconfig.extends.json 输入以下内容 
{ 
    "compilerOptions": { 
        "baseUrl": ".", 
        "paths": { 
            "@/*": ["src/*"] 
        } 
    } 
}

同时在import对应.ts文件时只具体到文件名,不加.ts后缀。

2)打包后地图无法显示:通过import引入ol,项目打包后切换map路由后会重复创建ol-viewport,导致地图无法显示(此时地图显示在第二个ol-viewport所在的div中,主界面部分显示的是第一个ol-viewport所在div);

解决:在路由切换时清除map.vue中创建的ol-viewport,如下:

ini 复制代码
onUnmounted(() => { 
    map.dispose(); 
    map = null 
})

注:直接引入ol.js,打包后不会出现该问题。

项目地址:github.com/DLFouge/vue...

欢迎指正与star

相关推荐
_codemonster1 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
wqq63108553 小时前
Python基于Vue的实验室管理系统 django flask pycharm
vue.js·python·django
Deng9452013143 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
Hello.Reader4 小时前
Flink 文件系统通用配置默认文件系统与连接数限制实战
vue.js·flink·npm
EchoEcho6 小时前
深入理解 Vue.js 渲染机制:从声明式到虚拟 DOM 的完整实现
vue.js
C澒6 小时前
Vue 项目渐进式迁移 React:组件库接入与跨框架协同技术方案
前端·vue.js·react.js·架构·系统架构
发现一只大呆瓜7 小时前
虚拟列表:从定高到动态高度的 Vue 3 & React 满分实现
前端·vue.js·react.js
鱼毓屿御8 小时前
如何给用户添加权限
前端·javascript·vue.js
Java新手村8 小时前
基于 Vue 3 + Spring Boot 3 的 AI 面试辅助系统:实时语音识别 + 大模型智能回答
vue.js·人工智能·spring boot
雯0609~8 小时前
hiprint:实现项目部署与打印3-vue版本-独立出模板设计与模板打印页面
前端·vue.js·arcgis