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

Vue利用openlayers實現(xiàn)點擊彈窗的方法詳解

 更新時間:2022年06月21日 11:21:31   作者:王+V  
點擊彈窗其實就是添加一個彈窗圖層,然后在點擊的時候讓他顯示出來罷了。本文將利用openlayers實現(xiàn)這一效果,快跟隨小編一起學(xué)習(xí)一下吧

這個寫的稍微簡單一點就行了,其實呢,這個不是很難,主要是知道原理就可以了。

我想實現(xiàn)的內(nèi)容是什么意思呢?就是說頁面上有很多坐標(biāo)點,點擊坐標(biāo)點的時候在相應(yīng)的位置彈出一個框,然后框里顯示出這個坐標(biāo)點的相關(guān)數(shù)據(jù)。

解釋

這個內(nèi)容的其實就是添加一個彈窗圖層,然后在點擊的時候讓他顯示出來罷了。

編寫彈窗

首先一點,我們這個彈窗需要自己寫一下,具體的樣式,展示的內(nèi)容之類的,所以說寫一個彈窗組件,然后在openlayer文件中引用加載。

比如我們創(chuàng)建一個 msgModel.vue

<template>
  <div class="msg-div">
    <p class="msg-title">{{data.title}}</p>
  </div>
</template>
<script>
  export default {
    props: ['data'],
    data() {
      return {
        
      }
    },
    methods: {
      
    },
  }
</script>
<style scoped>
.msg-div {
  min-width: 200px;
  padding: 0px;
  background-color: #fff;
  padding-bottom: 5px;
}
.msg-title {
  margin: 0;
  padding-left: 5px;
  height: 30px;
  line-height: 30px;
  font-size: 13px;
  color: #fff;
}
</style>

上邊是我自己隨便寫的DEMO,然后具體按照你自己的來。

引入

然后在openlayer文件引入。

import msgModel from '@/views/modules/wjw/demo/msgModel'

然后像正常使用子組件一樣加載一下就行。

    components: {
      msgModel,
    },

然后在界面加上。

<msg-model ref="msgForm" :data="data"></msg-model>

其中這個data是傳遞過去要展示的值。

openlayer使用彈窗組件

初始化地圖的時候,我們把這個彈窗加載到openlayer里面。

	overlayForm = new Overlay({  // 創(chuàng)建一個圖層
          element: this.$refs.msgForm.$el,   // 圖層綁定我們上邊的彈窗
          autoPan: true,
          autoPanAnimation: {
            duration: 250,
          }
        })
        overlayForm.setPosition(undefined)   // 設(shè)置彈窗位置,剛開始我們不讓他顯示,就是undefined就行
        map.addOverlay(overlayForm)  // 然后把彈窗的圖層加載到地圖上

上面的代碼寫完之后,地圖是沒有彈窗的,因為我沒沒有設(shè)置他的位置。

然后實現(xiàn)點擊彈出來。

點擊事件

比如說地圖上有坐標(biāo)點,我點擊坐標(biāo)點,然后彈出這個彈框,同時展示點擊坐標(biāo)點的數(shù)據(jù)信息。

	map.on('click', ev => {
          let pixel = ev.pixel   // 鼠標(biāo)點擊的位置,這個應(yīng)該是像素
          let mouse = ev.coordinate  // 鼠標(biāo)點擊的坐標(biāo)位置
          let feature = map.forEachFeatureAtPixel(pixel, (feature) => {
            return feature   // 查找出點擊的哪個坐標(biāo)
          })
          if (feature) {  // 如果是點擊了坐標(biāo)點
            this.data= feature.get('data')  // 獲取坐標(biāo)點的數(shù)據(jù)
            overlayForm.setPosition(mouse)  // 設(shè)置彈窗的位置
          } else {
            overlayForm.setPosition(undefined)  // 如果沒有點擊坐標(biāo)點,就隱藏彈窗
          }
        })

好了,上邊代碼基本上就實現(xiàn)了點擊坐標(biāo)點彈出信息框功能,就不截圖了,湊合看吧

到此這篇關(guān)于Vue利用openlayers實現(xiàn)點擊彈窗的方法詳解的文章就介紹到這了,更多相關(guān)Vue openlayers點擊彈窗內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中使用elementui實現(xiàn)樹組件tree右鍵增刪改功能

    vue中使用elementui實現(xiàn)樹組件tree右鍵增刪改功能

    這篇文章主要介紹了vue中使用elementui實現(xiàn)對樹組件tree右鍵增刪改功能,右擊節(jié)點可進(jìn)行增刪改,對節(jié)點數(shù)據(jù)進(jìn)行模糊查詢功能,本文給大家分享了完整代碼,需要的朋友可以參考下
    2022-08-08
  • vue如何獲取配置代理文件中的api地址值

    vue如何獲取配置代理文件中的api地址值

    這篇文章主要介紹了vue如何獲取配置代理文件中的api地址值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue3  defineExpose要在方法聲明定義以后使用的教程

    Vue3  defineExpose要在方法聲明定義以后使用的教程

    這篇文章主要介紹了Vue3  defineExpose要在方法聲明定義以后使用的教程,本文結(jié)合實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • vue文件上傳Required request part ‘file‘ is not present問題

    vue文件上傳Required request part ‘file‘ is&n

    這篇文章主要介紹了vue文件上傳Required request part ‘file‘ is not present問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Vue.js實現(xiàn)的購物車功能詳解

    Vue.js實現(xiàn)的購物車功能詳解

    這篇文章主要介紹了Vue.js實現(xiàn)的購物車功能,結(jié)合實例形式分析了vue.js購物車的原理、數(shù)值計算及頁面元素屬性動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2019-01-01
  • vue  elementUI 表單嵌套驗證的實例代碼

    vue elementUI 表單嵌套驗證的實例代碼

    這篇文章主要介紹了vue + elementUI 表單嵌套驗證,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-11-11
  • Vue如何處理Axios多次請求數(shù)據(jù)顯示問題

    Vue如何處理Axios多次請求數(shù)據(jù)顯示問題

    這篇文章主要介紹了Vue如何處理Axios多次請求數(shù)據(jù)顯示問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue實現(xiàn)登錄記住賬號密碼功能的思路與過程

    Vue實現(xiàn)登錄記住賬號密碼功能的思路與過程

    最近在學(xué)習(xí)vue,發(fā)現(xiàn)了vue的好多坑,下面這篇文章主要給大家介紹了關(guān)于Vue實現(xiàn)登錄記住賬號密碼功能的思路與過程,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-11-11
  • 解決@vue/cli安裝成功后,運行vue -V報:不是內(nèi)部或外部命令的問題

    解決@vue/cli安裝成功后,運行vue -V報:不是內(nèi)部或外部命令的問題

    這篇文章主要介紹了解決@vue/cli安裝成功后,運行vue -V報:不是內(nèi)部或外部命令的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • el-form-item?prop屬性動態(tài)綁定不生效問題及解決

    el-form-item?prop屬性動態(tài)綁定不生效問題及解決

    這篇文章主要介紹了el-form-item?prop屬性動態(tài)綁定不生效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07

最新評論