vue3 引入腾讯地图 进行地点搜索以及mark

<template>

<div style="position: relative;">

<div ref="container" id="container" style="width: 100%; height: 500px;"></div>

<el-input

v-model="address"

style="width: 100%; border-radius: 10px; position: absolute; top: 10px; left: 20px; width: 65%; display: flex; z-index: 99999;"

placeholder="请输入地址"

:suffix-icon="Search"

@input="bindChangeItem"

/>

<div class="waterfall-main" v-if="showMore">

<div class="address-item-list" v-for="item in addressData" :key="item.id" @click="bindChangeAdress(item)">

<span>{{ item.title }}</span>

<span class="address-item-list-right">{{ item.address }}</span>

</div>

</div>

</div>

<!-- <div class="address">

<el-form :model="form" label-width="auto" style="margin-top: 20px; width: 200px;">

<el-form-item label="区域">

<el-input v-model="form.name" />

</el-form-item>

</el-form>

</div> -->

</template>

<script lang="ts" setup>

import { ref, onMounted, nextTick } from 'vue';

import { Search } from '@element-plus/icons-vue'

import { debounce } from 'lodash';

import { jsonp } from "vue-jsonp";

const container = ref(null);

const address = ref('')

const addressData = ref<any []>([])

const showMore = ref(false)

const form = ref({

name: ''

})

let map:any = null

let markerLayer:any = null;

// 或者在Vue生命周期钩子中创建地图实例(推荐)

onMounted(() => {

console.log('333')

console.log((window as any).TMap)

if ((window as any).TMap) {

nextTick(()=> {

map = new (window as any).TMap.Map(container.value, {

center: new (window as any).TMap.LatLng(39.916527, 116.397128),

zoom: 15,

});

markerLayer = new (window as any).TMap.MultiMarker({

map: map

})

})

} else {

console.error("TMap API 未加载");

}

});

const bindChangeItem = debounce(() => {

console.log('搜索内容:', address.value);

if (address.value) {

const key = 'key'; // 替换为你的腾讯地图 API 密钥

// 构建请求 URL

const url = `https://apis.map.qq.com/ws/place/v1/suggestion\`;

jsonp (url, {

key: key,

region: '北京市',

output: "jsonp",

keyword: address.value,

}).then((res)=> {

console.log(res)

addressData.value = res.data

})

showMore.value = true

}

}, 3000)// 1000 毫秒的防抖时间

const bindChangeAdress = (item: any)=> {

console.log(item)

address.value = item.title

showMore.value = false

handleChange(item)

}

// 选中地址 设置当前点位

const handleChange = (object: any) => {

setMapMarker(object)

}

// 放置地图点位

const setMapMarker = (locationObj: any) => {

const { lat, lng } = locationObj.location

markerLayer.setGeometries([])

markerLayer.add({

position: new (window as any).TMap.LatLng(lat, lng)

})

// 自动定位到中间

const bounds = new (window as any).TMap.LatLngBounds()

bounds.extend(new (window as any).TMap.LatLng(lat, lng))

map.fitBounds(bounds)

}

</script>

<style lang="scss" scoped>

.waterfall-main {

width: 65%;

position: absolute;

left: 20px;

top: 50px;

background: #fff;

z-index: 99999;

font-size: 14px;

padding: 10px 20px;

cursor: pointer;

.address-item-list {

line-height: 30px;

.address-item-list-right {

margin-left: 10px;

color: rgb(131, 131, 131);

font-size: 12px;

}

}

// .address :deep(.el-input__inner .el-input__wrapper) {

// border: 1px solid red !important;

// }

}

</style>

相关推荐
程序员林北北1 小时前
【前端进阶之旅】节流与防抖:前端性能优化的“安全带”与“稳定器”
前端·javascript·vue.js·react.js·typescript
寻星探路2 小时前
【前端基础】HTML + CSS + JavaScript 快速入门(三):JS 与 jQuery 实战
java·前端·javascript·css·c++·ai·html
未来龙皇小蓝6 小时前
RBAC前端架构-04:设置代理及开发配置
前端·vue.js
SuperEugene6 小时前
对象数组的排序与分组:sort / localeCompare / 自定义 compare
前端·javascript·面试
扶苏10027 小时前
“解构”与“响应”的博弈——深入剖析 Vue 3 的 toRef 与 toRefs
前端·javascript·vue.js
Channing Lewis7 小时前
zoho crm的子表添加行时,有一个勾选字段,如何让它在details页面新建子表行(点击add row)时默认是勾选的
开发语言·前端·javascript
董员外8 小时前
LangChain.js 快速上手指南:模型接入、流式输出打造基础
前端·javascript·后端
用户4099322502128 小时前
Vue3组件开发中如何兼顾复用性、可维护性与性能优化?
前端·vue.js·trae
千寻girling8 小时前
面试官 : “ 请问你实际开发中用过 函数柯理化 吗? 能讲一下吗 ?”
前端·javascript·面试
change_fate9 小时前
vite 修改base之后需要修改public路径
javascript·vue.js