当前位置: 首页 > wzjs >正文

学做网页设计标题关键词优化报价

学做网页设计,标题关键词优化报价,网页设计是什么意思,旅游英文网站 建设需求在前端 GIS(地理信息系统)开发中,OpenLayers 是一个强大的开源地图库,可以帮助开发者快速构建 Web 地图应用。本文将详细介绍如何在 Vue3 项目中,使用 OpenLayers 并结合 marker-feature 插件来添加 Marker。 1. 项目初…

在前端 GIS(地理信息系统)开发中,OpenLayers 是一个强大的开源地图库,可以帮助开发者快速构建 Web 地图应用。本文将详细介绍如何在 Vue3 项目中,使用 OpenLayers 并结合 marker-feature 插件来添加 Marker


1. 项目初始化

如果你的 Vue3 项目还没有创建,可以使用 Vite 进行快速搭建:

npm create vite@latest vue-openlayers-demo --template 
vue cd vue-openlayers-demo npm install

然后安装 OpenLayersmarker-feature 插件:

npm install ol ol-marker-feature ol-popup

2. 创建 MarkerFeature.vue 组件

components 目录下新建 MarkerFeature.vue,然后使用 setup 语法来封装 OpenLayers 地图,并添加 marker-feature

<!--* @Author: 彭麒* @Date: 2025/3/12* @Email: 1062470959@qq.com* @Description: 此源码版权归吉檀迦俐所有,可供学习和借鉴或商用。-->  
<template><div class="container"><div class="w-full flex justify-center"><div class="font-bold text-[24px]">在Vue3 + OpenLayers使用 marker-feature 来添加 marker</div></div><div id="vue-openlayers"></div></div>
</template><script setup>
import { onMounted } from "vue";
import "ol/ol.css";
import { Map, View } from "ol";
import Tile from "ol/layer/Tile";
import OSM from "ol/source/OSM";
import Marker from "ol-marker-feature";
import Popup from "ol-popup";let map; // map 作为普通变量,不使用 refconst initMap = () => {if (map) return; // 避免重复初始化const OSMlayer = new Tile({ source: new OSM() });map = new Map({target: "vue-openlayers",layers: [OSMlayer],view: new View({center: [113.448, 23.986],zoom: 7,projection: "EPSG:4326",}),});const marker = new Marker([113.448, 23.986]);marker.set("info",`<div style="background:#fff; padding:20px;"><h3>我的 Marker 标题</h3><h4>vue-openlayers 的信息内容</h4></div>`);marker.setMap(map);const popup = new Popup({ offset: [0, -32] });map.addOverlay(popup);marker.on("click", () => {popup.show(marker.getLocation(), marker.get("info"));});
};onMounted(initMap);
</script><style scoped>
.container {width: 840px;height: 590px;margin: 50px auto;border: 1px solid #42B983;
}
#vue-openlayers {width: 800px;height: 470px;margin: 0 auto;border: 1px solid #42B983;position: relative;
}
</style>

3. 组件解析

3.1 OpenLayers 地图初始化

我们创建了一个 OSM(OpenStreetMap)底图,并在 div#vue-openlayers 内渲染 Map 实例:

map = new Map({ target: "vue-openlayers", layers: [OSMlayer], view: new View({ center: [113.448, 23.986], zoom: 7, projection: "EPSG:4326", }), 
});

注意:OpenLayers 默认使用 EPSG:3857 投影,因此如果你的坐标是 EPSG:4326,请确保所有数据一致。


3.2 添加 Marker

ol-marker-feature 允许我们直接创建 Marker 并绑定到 Map

const marker = new Marker([113.448, 23.986]); 
marker.set("info", "<div>Vue3 OpenLayers Marker</div>"); 
marker.setMap(map);

这样,我们的 Marker 就会出现在指定经纬度的位置。


3.3 绑定 Popup 信息框

为了让 Marker 可以在点击时弹出 Popup,我们使用 ol-popup 插件:

const popup = new Popup({ offset: [0, -32] }); 
map.addOverlay(popup); 
marker.on("click", () => { popup.show(marker.getLocation(), marker.get("info")); 
});

这样,点击 Marker 时就能弹出对应的 HTML 内容。


4. 在 App.vue 引用组件

App.vue 中引入 MarkerFeature.vue 并使用:

<template> <MarkerFeature /> 
</template> 
<script setup> import MarkerFeature from "./components/MarkerFeature.vue"; 
</script>

5. 运行项目

npm run dev

打开浏览器,访问 http://localhost:5173(默认 Vite 端口),你应该可以看到地图,以及点击 Marker 后弹出的 Popup 信息框。


6. 常见问题

Uncaught TypeError: Class constructor _Feature cannot be invoked without 'new'

如果 ol-marker-feature 发生此错误,可以使用 Feature + Point 方式替代:

import Feature from "ol/Feature"; 
import Point from "ol/geom/Point"; 
import VectorLayer from "ol/layer/Vector"; 
import VectorSource from "ol/source/Vector"; 
import { Icon, Style } from "ol/style"; 
import { fromLonLat } from "ol/proj"; // 使用 Feature + Point 方式创建 Marker 
const markerFeature = new Feature({ geometry: new Point(fromLonLat([113.448, 23.986])), 
}); 
markerFeature.setStyle( new Style({ image: new Icon({ anchor: [0.5, 1], src: "https://openlayers.org/en/latest/examples/data/icon.png", // 自定义图标 }), 
}) ); // 创建矢量图层 
const vectorLayer = new VectorLayer({ source: new VectorSource({ features: [markerFeature], }), 
}); 
map.addLayer(vectorLayer);

推荐:如果 marker-feature 兼容性不好,建议直接用 Feature + Point 方式实现。


7. 总结

  • Vue3 + OpenLayers 提供了强大的 Web 地图能力
  • marker-feature 可以快速添加 Marker,但兼容性可能有问题
  • 推荐使用 Feature + Point 方式 来实现 Marker
  • 可以结合 ol-popup 添加信息弹窗交互

8. 参考文档

  • OpenLayers 官网
  • ol-marker-feature GitHub
  • Vue.js 官网

这样,你的 CSDN 文章就完成了!🚀 希望能帮到你,记得给文章加点排版,效果会更好哦! 🎉

http://www.dtcms.com/wzjs/493282.html

相关文章:

  • asp.net 旅游网站开发长沙百度网站快速排名
  • 网站专题页面开发查看关键词被搜索排名的软件
  • 做网络推广应该去哪些网站推广呢国内十大软件测试培训机构
  • dedecms 手机网站模板营销型网站设计制作
  • 网站建设需要多久温州网站快速排名
  • 武昌有专业做网站网络营销的案例有哪些
  • 抖音小程序官网seo工具优化软件
  • 33岁改行做网站建设优化防控举措
  • 网页游戏网站hpjy千瓜数据
  • 网站建设亿玛酷专注nba排名最新赛程
  • 无锡哪家做网站好营销网络图
  • 网站定制型和营销型seo营销推广
  • 企业网站招聘可以怎么做怎样有效的做网上宣传
  • 龙岩网站建设公司百度竞价开户需要多少钱
  • 国外做的好的鲜花网站济南网站建设公司
  • 如何手机做任务赚钱的网站大数据查询官网
  • 网站建设学习多少钱内部搜索引擎优化
  • 嘉定网站设计网站seo排名
  • 华大基因 网站建设公司seo黑帽培训骗局
  • ppt 做的最好的网站杭州seo排名收费
  • 网站后期维护费用seo标题优化裤子关键词
  • 动态网站的好处社群营销的十大步骤
  • 给有后台的网站做网页网页搜索引擎大全
  • 网站的经营方式seo怎么做排名
  • 高校网站建设与管理问题分析今日关注
  • 网站banner图怎么做seo指的是搜索引擎营销
  • qq号码免费申请长治seo
  • 网站推广无锡写软文一篇多少钱合适
  • 烟台汽车网站建设咖啡seo是什么意思
  • 天津建设电工证查询网站优化排名工具