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

Vue結合高德地圖實現(xiàn)HTML寫自定義信息彈窗全過程

 更新時間:2023年04月11日 08:44:22   作者:呈兩面包夾芝士  
最近開發(fā)中遇到一個多個點繪制,并實現(xiàn)點擊事件,出現(xiàn)自定義窗口顯示相關信息等功能,下面這篇文章主要給大家介紹了關于Vue結合高德地圖實現(xiàn)HTML寫自定義信息彈窗的相關資料,需要的朋友可以參考下

最近在寫項目的時候有個需求就是根據(jù)點擊地圖上的點展示對應的信息,彈窗看著還挺花哨的。我在高德地圖官網(wǎng)上還有各大平臺找了如何自定義彈窗,可給出的大多數(shù)都是通過JS寫HTML結構,我感覺這種不僅不好布局,而且可讀性和維護性都不如直接寫HTML好。于是我就在想,能不能在HTML里寫這個彈窗呢?

答案是:!

效果圖如下:

先說下思路吧,通過看高德地圖官方文檔關于InfoWindow的介紹,可以看出信息彈窗的顯示內容,可以是HTML要素字符串或者HTMLElement對象。于是我就想到了在Vue里不是可以通過this.$refs獲取元素的DOM節(jié)點嗎?然后我就開始了第一次嘗試。

先看下后臺返回的數(shù)據(jù)類型:

      data: [
        {
          id: '1', //id
          projectName: 'xxxx項目', //項目名稱
          address: '山東省濟南市市中區(qū)xxxxxxxxxx', //項目地址
          sketchMapUrl: '116.998232,36.651352', //項目坐標
          startDate: '2022-06-18', //計劃開始日期
          completedDate: '2022-11-18', //計劃結束日期
          progress: '78', //施工進度
          buildPeople: '32', //施工人員
          alarmNum: '8' //告警信息數(shù)目
        },{
          id: '2', //id
          projectName: 'xxxx項目', //項目名稱
          address: '山東省濟南市市中區(qū)xxxxxxxxxx', //項目地址
          sketchMapUrl: '116.998232,36.651352', //項目坐標
          startDate: '2022-06-18', //計劃開始日期
          completedDate: '2022-11-18', //計劃結束日期
          progress: '78', //施工進度
          buildPeople: '32', //施工人員
          alarmNum: '8' //告警信息數(shù)目
        }
      ],

我一看這種數(shù)據(jù)類型不就是用v-for嗎?但是這個時候問題來了,不能直接循環(huán)后臺返回的數(shù)據(jù)!

原因有二:

  • 高德地圖的AMap.InfoWindow的content屬性不支持多個DOM根節(jié)點
  • 不知道用戶點擊的哪一個點

必須經(jīng)過篩選,判斷用戶點擊的點.

this.data.map((item) => {
    this.arr = item.sketchMapUrl.split(',')
    //自定義點圖標
    this.marker = new AMap.Marker({
        map: this.map,
        icon: this.icon,
        position: [this.arr[0], this.arr[1]],
        offset: new AMap.Pixel(-13, -30),
        //注意,我這里判斷是給點加了個額外的參數(shù),就是數(shù)據(jù)的id
        extData: item.id
    })
    this.marker.on('click', (e) => {
        this.singleData = []
        //這里通過e.target._opts.extData和item.id進行比對,如果相同則把這項點的信息單獨放一個數(shù)組里去遍歷,就是html里的遍歷數(shù)組
        if (e.target._opts.extData === item.id) {
           this.singleData.push(item)
        }
    this.infoWindow.open(this.map, e.target.getPosition())
    })
})

這個時候可以判斷點擊的點了,下一步要做的就是實現(xiàn)自定義彈窗了。

代碼如下:

<template>
  <div class="web-box">
  	 <!-- 地圖 -->
    <div id="map"></div>

    <!-- 地圖彈窗 -->
    <div ref="infoWindow" class="infoWindow" >
      <div class="container" v-for="(item,index) in singleData" :key="index">
	    <!-- 這里面寫彈窗布局樣式 -->
      </div>
  </div>
</template>

js代碼:

 //自定義信息窗體
this.infoWindow = new AMap.InfoWindow({
  	isCustom: true,
  	autoMove: true,
	avoid: [20, 20, 20, 20],
    content: this.$refs.infoWindow,
    closeWhenClickMap: true,
    offset: new AMap.Pixel(16, -30)
})

通過this.$refs.infoWindow拿到在HTML里寫的彈窗節(jié)點,放在content內,這樣我們就可以不用再寫一些innerHTMLappendChild此類的代碼了!

總結

到此這篇關于Vue結合高德地圖實現(xiàn)HTML寫自定義信息彈窗的文章就介紹到這了,更多相關Vue自定義信息彈窗內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue Element前端應用開發(fā)之常規(guī)Element界面組件

    Vue Element前端應用開發(fā)之常規(guī)Element界面組件

    在我們開發(fā)BS頁面的時候,往往需要了解常規(guī)界面組件的使用,小到最普通的單文本輸入框、多文本框、下拉列表,以及按鈕、圖片展示、彈出對話框、表單處理、條碼二維碼等等,本篇隨筆基于普通表格業(yè)務的展示錄入的場景介紹這些常規(guī)Element組件的使用
    2021-05-05
  • 詳解在不使用ssr的情況下解決Vue單頁面SEO問題

    詳解在不使用ssr的情況下解決Vue單頁面SEO問題

    這篇文章主要介紹了在不使用ssr的情況下解決Vue單頁面SEO問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 如何在vue中使用ts的示例代碼

    如何在vue中使用ts的示例代碼

    本篇文章主要介紹了如何在vue中使用ts的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • vue2+elementui上傳照片方式(el-upload超簡單)

    vue2+elementui上傳照片方式(el-upload超簡單)

    這篇文章主要介紹了vue2+elementui上傳照片方式(el-upload超簡單),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue路由傳遞參數(shù)與重定向的使用方法總結

    Vue路由傳遞參數(shù)與重定向的使用方法總結

    路由的本質就是一種對應關系,比如說我們在url地址中輸入我們要訪問的url地址之后,瀏覽器要去請求這個url地址對應的資源,下面這篇文章主要給大家介紹了關于Vue路由傳遞參數(shù)與重定向的使用方法,需要的朋友可以參考下
    2022-10-10
  • Vue后臺中優(yōu)雅書寫狀態(tài)標簽的方法實例

    Vue后臺中優(yōu)雅書寫狀態(tài)標簽的方法實例

    在Vue中,我們可以非常便捷地通過標簽實現(xiàn)狀態(tài)的保存,這篇文章主要給大家介紹了關于Vue后臺中如何優(yōu)雅的書寫狀態(tài)標簽的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-08-08
  • 詳解Vue+elementUI build打包部署后字體圖標丟失問題

    詳解Vue+elementUI build打包部署后字體圖標丟失問題

    這篇文章主要介紹了詳解Vue+elementUI build打包部署后字體圖標丟失問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • vue自定義全局組件(自定義插件)的用法

    vue自定義全局組件(自定義插件)的用法

    這篇文章主要介紹了vue自定義全局組件(自定義插件)的用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Vue中render函數(shù)的使用方法

    Vue中render函數(shù)的使用方法

    本篇文章主要介紹了Vue中render函數(shù)的使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Vue路由之JWT身份認證的實現(xiàn)方法

    Vue路由之JWT身份認證的實現(xiàn)方法

    這篇文章主要介紹了Vue路由之JWT身份認證的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08

最新評論