欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何在 Vue3 中使用 OpenLayers 實現(xiàn)事件 loadstart 和 loadend

 更新時間:2025年04月01日 11:00:41   作者:吉檀迦俐  
在這篇文章中,我將詳細(xì)介紹如何在 Vue3 + OpenLayers 中監(jiān)聽 loadstart 和 loadend 事件,并通過 Vue3 Composition API 進(jìn)行代碼優(yōu)化,使其更加高效、健壯,感興趣的朋友一起看看吧

前言

在前端 GIS (地理信息系統(tǒng)) 開發(fā)中,OpenLayers 是一個功能強(qiáng)大的地圖庫,可以幫助開發(fā)者輕松實現(xiàn)地圖渲染、交互以及各種地理數(shù)據(jù)的可視化。
在地圖加載過程中,我們通常希望在加載開始時顯示加載動畫 (loadstart),在加載完成后隱藏加載動畫 (loadend)。

在這篇文章中,我將詳細(xì)介紹如何在 Vue3 + OpenLayers 中監(jiān)聽 loadstartloadend 事件,并通過 Vue3 Composition API 進(jìn)行代碼優(yōu)化,使其更加高效、健壯。

1. OpenLayers 加載事件

OpenLayers 中,地圖瓦片 (TileLayer) 本身并不會觸發(fā) loadstartloadend 事件,而是 TileLayer 的數(shù)據(jù)源 (source) 觸發(fā):

  • tileloadstart: 瓦片開始加載時觸發(fā)。
  • tileloadend: 瓦片加載完成時觸發(fā)。
  • tileloaderror: 瓦片加載失敗時觸發(fā)(避免加載失敗時動畫一直不消失)。

因此,我們需要監(jiān)聽 source 事件,而不是 map 本身。

2. 在 Vue3 + OpenLayers 中實現(xiàn) loadstart 和 loadend

我們將使用 Vue3 的 Composition API 來實現(xiàn),確保代碼清晰且符合現(xiàn)代 Vue 開發(fā)規(guī)范。

完整代碼

<!--
 * @Author: 彭麒
 * @Date: 2025/3/31
 * @Email: 1062470959@qq.com
 * @Description: 此源碼版權(quán)歸吉檀迦俐所有,可供學(xué)習(xí)和借鑒或商用。
 -->
<template>
  <div class="container">
    <div class="w-full flex justify-center flex-wrap">
      <div class="font-bold text-[24px]">在Vue3中使用OpenLayers實現(xiàn)事件 loadstart 和 loadend 的示例</div>
    </div>
    <div id="vue-openlayers"></div>
  </div>
</template>
<script setup>
import { onMounted, ref } from 'vue';
import 'ol/ol.css';
import { Map, View } from 'ol';
import TileLayer from 'ol/layer/Tile';
import OSM from 'ol/source/OSM';
const map = ref(null);
const loadEvent = () => {
  if (!map.value) return;
  map.value.on('loadstart', () => {
    map.value.getTargetElement().classList.add('spinner');
  });
  map.value.on('loadend', () => {
    map.value.getTargetElement().classList.remove('spinner');
  });
};
const initMap = () => {
  const OSM_Layer = new TileLayer({
    source: new OSM(),
  });
  map.value = new Map({
    target: 'vue-openlayers',
    layers: [OSM_Layer],
    view: new View({
      projection: 'EPSG:4326',
      center: [116.15, 40.79],
      zoom: 6,
    }),
  });
};
onMounted(() => {
  initMap();
  loadEvent();
});
</script>
<style scoped>
.container {
  width: 840px;
  height: 570px;
  margin: 50px auto;
  border: 1px solid #42B983;
}
#vue-openlayers {
  width: 800px;
  height: 450px;
  margin: 0 auto;
  border: 1px solid #42B983;
  position: relative;
}
@keyframes spinner {
  to {
    transform: rotate(360deg);
  }
}
.spinner:after {
  content: "";
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  margin-left: -20px;
  border-radius: 50%;
  border: 5px solid rgba(180, 180, 180, 0.6);
  border-top-color: rgba(0, 0, 0, 0.6);
  animation: spinner 0.6s linear infinite;
}
</style>

3. 代碼解析

(1)初始化地圖

const initMap = () => { 
    OSM_Layer = new TileLayer({ source: new OSM(), 
}); 
map.value = new Map({ 
    target: 'vue-openlayers', 
    layers: [OSM_Layer], 
    view: new View({ 
        projection: 'EPSG:4326', 
        center: [116.15, 40.79], zoom: 6, 
        }), 
    }); 
};

這里我們使用 OpenStreetMap 作為地圖瓦片數(shù)據(jù)源 (OSM()),并將地圖掛載到 #vue-openlayersdiv 中。

(2)監(jiān)聽 loadstart 和 loadend 事件

const loadEvent = () => { 
    if (!OSM_Layer) return; 
    const source = OSM_Layer.getSource(); 
    if (!source) return; 
    const onLoadStart = () => { 
        map.value?.getTargetElement()?.classList.add('spinner'); 
    }; 
    const onLoadEnd = () => { 
        map.value?.getTargetElement()?.classList.remove('spinner'); 
    }; 
    source.on('tileloadstart', onLoadStart); 
    source.on('tileloadend', onLoadEnd);         
    source.on('tileloaderror', onLoadEnd);
     return { onLoadStart, onLoadEnd }; 
};
  • tileloadstart: 當(dāng)?shù)貓D瓦片開始加載時,添加 spinner 類,實現(xiàn)加載動畫。
  • tileloadend / tileloaderror: 瓦片加載完成或失敗后,移除 spinner 類,隱藏加載動畫。

(3)在 Vue 生命周期中掛載和卸載事件

  • onMounted: 組件掛載時初始化地圖,并綁定 loadstartloadend 事件。
  • onUnmounted: 組件銷毀時,解綁事件,防止內(nèi)存泄漏。

4. 運行效果

當(dāng)?shù)貓D瓦片開始加載時,會出現(xiàn)一個 加載動畫,當(dāng)瓦片加載完成或失敗時,動畫會消失。

5. 總結(jié)

本文介紹了如何在 Vue3 + OpenLayers 項目中監(jiān)聽 loadstartloadend 事件,實現(xiàn)地圖加載動畫:

  • 確監(jiān)聽 tileloadstarttileloadend 事件。
  • 使用 onMountedonUnmounted 進(jìn)行事件綁定和解綁,確保代碼健壯性。
  • 通過 CSS 設(shè)計簡單的加載動畫。

希望這篇文章能幫助到你,如果有問題,歡迎留言交流!??

到此這篇關(guān)于如何在 Vue3 中使用 OpenLayers 實現(xiàn)事件 loadstart 和 loadend的文章就介紹到這了,更多相關(guān)Vue3使用 OpenLayers內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于VUE的v-charts的曲線顯示功能

    基于VUE的v-charts的曲線顯示功能

    這篇文章主要介紹了基于VUE的v-charts的曲線顯示功能,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • easycom模式開發(fā)UNI-APP組件調(diào)用必須掌握的實用技巧

    easycom模式開發(fā)UNI-APP組件調(diào)用必須掌握的實用技巧

    uni-app基于VUE開發(fā),通常組件的使用都是先安裝,然后全局或者局部引入,注冊,今天通過本文給大家分享easycom模式開發(fā)UNI-APP組件調(diào)用必須掌握的實用技巧,需要的朋友一起看看吧
    2021-08-08
  • Vue之vue.$set()方法源碼案例詳解

    Vue之vue.$set()方法源碼案例詳解

    這篇文章主要介紹了Vue之vue.$set()方法源碼案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 編寫v-for循環(huán)的技巧匯總

    編寫v-for循環(huán)的技巧匯總

    這篇文章主要介紹了編寫更好的v-for循環(huán)的6種技巧,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12
  • vue動態(tài)設(shè)置img的src路徑實例

    vue動態(tài)設(shè)置img的src路徑實例

    今天小編就為大家分享一篇vue動態(tài)設(shè)置img的src路徑實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解使用vue-router進(jìn)行頁面切換時滾動條位置與滾動監(jiān)聽事件

    詳解使用vue-router進(jìn)行頁面切換時滾動條位置與滾動監(jiān)聽事件

    本篇文章主要介紹了詳解使用vue-router進(jìn)行頁面切換時滾動條位置與滾動監(jiān)聽事件,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • Vue中圖片的引用方式的區(qū)別詳解

    Vue中圖片的引用方式的區(qū)別詳解

    在?Vue?開發(fā)中,圖片的引用方式主要取決于圖片存放的位置,一般有四種常用的存放方式,本文將詳細(xì)分析這些方式的區(qū)別,并提供完整的代碼示例,希望對大家有所幫助
    2025-02-02
  • vue的傳參方式匯總和router使用技巧

    vue的傳參方式匯總和router使用技巧

    這篇文章主要介紹了vue的傳參方式和router使用技巧,本文給大家列舉了好幾種傳參方式,需要的朋友可以參考下
    2018-05-05
  • Vue實現(xiàn)簡單計算器

    Vue實現(xiàn)簡單計算器

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)簡單計算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • vue中過濾器的用法

    vue中過濾器的用法

    這篇文章介紹了vue中過濾器的用法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03

最新評論