vue用用BMap百度地图实现即时搜索功能百度地图实现即时搜索功能
主要为大家详细介绍了vue用BMap百度地图实现即时搜索功能,具有一定的参考价值,感兴趣的小伙伴们可以
参考一下
本文实例为大家分享了vue用BMap百度地图实现即时搜索功能的具体代码,供大家参考,具体内容如下
功能如下:功能如下:
搜索框搜索---自动下拉---点击数据---数据显示在搜索框里---点击新增--数据显示在下方--点击删除--删除当前
代码:代码:
首先去百度开发者申请一个key
然后将key引入到项目的 index.html:
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=你的key"></script>
下面是组件代码:
<template>
<div id="app">
<el-form label-width="200px">
<el-form-item label="包含小区" required class="housing_input">
<el-input id="suggestId" v-model="city" placeholder="请输入小区名称" name="address_detail" />
<div id="allmap"/>
<el-button @click="add_housing">新增</el-button>
<div v-for="(item,index) in add_housing_list" :key="index" class="housingList">
<span>{{item}}</span>
<el-button class="delete_button" @click="delete_housing(index)">删除</el-button>
</div>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
name: 'demo',
data(){
return{
city: '',
address_detail: null, //详细地址
add_housing_list: ["阿里巴巴"],
}
},
mounted() {
this.getcity()
},
methods:{
getcity(){
this.$nextTick(function() {
var th = this
// 创建Map实例
var map = new BMap.Map('allmap')
// 初始化地图,设置中心点坐标,
var point = new BMap.Point(120.211877, 30.255194) // 创建点坐标,汉得公司的经纬度坐标
map.centerAndZoom(point, 15)
map.enableScrollWheelZoom()
var ac = new BMap.Autocomplete( // 建立一个自动完成的对象
{
'input': 'suggestId',
'location': map
})
var myValue
ac.addEventListener('onconfirm', function(e) { // 鼠标点击下拉列表后的事件
var _value = e.item.value //获取点击的条目
myValue = _value.province + _value.city + _value.district + _value.street + _value.business //地址拼接赋给一个变量
th.city = myValue //将地址赋给data中的city
// console.log(th.city)
setPlace()
})
// console.log(ac.pc.input)
评论0