vue用BMap百度地图实现即时搜索功能


Posted in Javascript onSeptember 26, 2019

 本文实例为大家分享了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)
 function setPlace() {
 map.clearOverlays() // 清除地图上所有覆盖物
 function myFun() {
  th.userlocation = local.getResults().getPoi(0).point // 获取第一个智能搜索的结果
  map.centerAndZoom(th.userlocation, 18)
  map.addOverlay(new BMap.Marker(th.userlocation)) // 添加标注
 }
 
 var local = new BMap.LocalSearch(map, { // 智能搜索
  onSearchComplete: myFun
 })
 local.search(myValue)
 
 // 测试输出坐标(指的是输入框最后确定地点的经纬度)
 map.addEventListener('click', function(e) {
  // 经度
  console.log(th.userlocation.lng)
  // 纬度
  console.log(th.userlocation.lat)
 })
 }
 },)
 },
 // 新增小区 点击的地址增加进list
 add_housing() {
 this.add_housing_list.push(this.city)
 },
 // 删除小区
 delete_housing(index) {
 // console.log(index)
 this.add_housing_list.splice(index, 1)
 },
}
}
</script>
 
<style scoped>
.housingList{
 margin-top:20px;
}
.delete_button{
 color: #409EFF;
 text-decoration: underline;
 border:none;
 background:#fff;
 cursor: pointer;
 margin-left:20px;
}
 
.el-input{
 width: 800px;
 }
 .housing_input .el-input{
 width: 730px;
 }
 
 #allmap{
 width: 400px;
 height: 400px;
 font-family: "微软雅黑";
 display: none;
}
 
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript YUI 读码日记之 YAHOO.util.Dom - Part.2 0
Mar 22 Javascript
js截取函数(indexOf,join等)
Sep 01 Javascript
再谈querySelector和querySelectorAll的区别与联系
Apr 20 Javascript
php的文件上传入门教程(实例讲解)
Apr 10 Javascript
javascript中createElement的两种创建方式
May 14 Javascript
jQuery插件制作的实例教程
May 16 Javascript
所见即所得的富文本编辑器bootstrap-wysiwyg使用方法详解
May 27 Javascript
移动端日期插件Mobiscroll.js使用详解
Dec 19 Javascript
JS+DIV实现的卷帘效果示例
Mar 22 Javascript
JavaScript中的return布尔值的用法和原理解析
Aug 14 Javascript
微信小程序使用slider设置数据值及switch开关组件功能【附源码下载】
Dec 09 Javascript
详解滑动穿透(锁body)终极探索
Apr 16 Javascript
layui.tree组件的使用以及搜索节点功能的实现
Sep 26 #Javascript
微信小程序点击列表跳转到对应详情页过程解析
Sep 26 #Javascript
vue+element tabs选项卡分页效果
Jun 29 #Javascript
layui实现根据table数据判断按钮显示情况的方法
Sep 26 #Javascript
vue+element表格导出为Excel文件
Sep 26 #Javascript
利用layer实现表单完美验证的方法
Sep 26 #Javascript
vue点击当前路由高亮小案例
Sep 26 #Javascript
You might like
剖析 PHP 中的输出缓冲
2006/12/21 PHP
PHP获取指定时间段之间的 年,月,天,时,分,秒
2016/06/05 PHP
php微信开发之带参数二维码的使用
2016/08/03 PHP
PHP 中使用ajax时一些常见错误总结整理
2017/02/27 PHP
php+croppic.js实现剪切上传图片功能
2018/08/14 PHP
jquery统计用户选中的复选框的个数
2014/06/06 Javascript
深入分析escape()、encodeURI()、encodeURIComponent()的区别及示例
2014/08/04 Javascript
jQuery向后台传入json格式数据的方法
2015/02/13 Javascript
深入理解JavaScript系列(31):设计模式之代理模式详解
2015/03/03 Javascript
jquery实现简单合拢与展开网页面板的方法
2015/09/01 Javascript
跟我学习javascript的prototype,getPrototypeOf和__proto__
2015/11/17 Javascript
JS本地刷新返回上一页代码
2016/07/25 Javascript
浅谈es6语法 (Proxy和Reflect的对比)
2017/10/24 Javascript
Vue组件化开发思考
2018/02/02 Javascript
JavaScript常见鼠标事件与用法分析
2019/01/03 Javascript
通过js给网页加上水印背景实例
2019/06/17 Javascript
微信小程序JS加载esmap地图的实例详解
2019/09/04 Javascript
React中使用Vditor自定义图片详解
2020/12/25 Javascript
[04:09]2018年度DOTA2社区贡献奖-完美盛典
2018/12/16 DOTA
一则python3的简单爬虫代码
2014/05/26 Python
python实现批量视频分帧、保存视频帧
2019/05/31 Python
pyqt5 QScrollArea设置在自定义侧(任何位置)
2019/09/25 Python
详解CSS3中nth-child与nth-of-type的区别
2017/01/05 HTML / CSS
英国最大的宠物食品和宠物用品网上零售商: Zooplus
2016/08/01 全球购物
彪马加拿大官网:PUMA加拿大
2018/10/04 全球购物
中海讯通笔试题
2015/09/15 面试题
计算机应用专业应届毕业生中文求职信范文
2013/11/29 职场文书
施工安全责任书
2014/04/14 职场文书
单位综合评价意见
2015/06/05 职场文书
吴仁宝观后感
2015/06/09 职场文书
教师个人工作总结范文2015
2015/10/14 职场文书
基层医务人员三严三实心得体会
2016/01/05 职场文书
CSS完成视差滚动效果
2021/04/27 HTML / CSS
mysql sum(if())和count(if())的用法说明
2022/01/18 MySQL
Anaconda安装pytorch和paddle的方法步骤
2022/04/03 Python
Centos系统通过Docker安装并搭建MongoDB数据库
2022/04/12 MongoDB