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中onclick(this)用法介绍
Apr 19 Javascript
tangram框架响应式加载图片方法
Nov 21 Javascript
javascript中加号(+)操作符的一些神奇作用
Jun 06 Javascript
使用javascript实现Iframe自适应高度
Dec 24 Javascript
JavaScript的内存释放问题详解
Jan 21 Javascript
如何给ss bash 写一个 WEB 端查看流量的页面
Mar 23 Javascript
利用Jasmine对Angular进行单元测试的方法详解
Jun 12 Javascript
js判断传入时间和当前时间大小实例(超简单)
Jan 11 Javascript
浅谈React碰到v-if
Nov 04 Javascript
详解使用uni-app开发微信小程序之登录模块
May 09 Javascript
Webpack按需加载打包chunk命名的方法
Sep 22 Javascript
vue实现移动端省市区选择
Sep 27 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
discuz Passport 通行证 整合笔记
2008/06/30 PHP
PHP中批量生成静态html(命令行下运行PHP)
2014/04/19 PHP
PHP启动windows应用程序、执行bat批处理、执行cmd命令的方法(exec、system函数详解)
2014/10/20 PHP
浅谈php(codeigniter)安全性注意事项
2017/04/06 PHP
PHP在弹框中获取foreach中遍历的id值并传递给地址栏
2017/06/13 PHP
PHP简单获取上月、本月、近15天、近30天的方法示例
2017/07/03 PHP
PHP的PDO连接讲解
2019/01/24 PHP
javascript Zifa FormValid 0.1表单验证 代码打包下载
2007/06/08 Javascript
JS 获取浏览器和屏幕宽高等信息的实现思路及代码
2013/07/31 Javascript
javaScript 动态访问JSon元素示例代码
2013/08/30 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(一)
2016/05/17 Javascript
基于AngularJs + Bootstrap + AngularStrap相结合实现省市区联动代码
2016/05/30 Javascript
angularjs 源码解析之scope
2016/08/22 Javascript
Bootstrap CSS组件之导航条(navbar)
2016/12/17 Javascript
jQuery.cookie.js实现记录最近浏览过的商品功能示例
2017/01/23 Javascript
vue-cli的eslint相关用法
2017/09/29 Javascript
koa-router路由参数和前端路由的结合详解
2019/05/19 Javascript
vue中nextTick用法实例
2019/09/11 Javascript
JavaScript Html实现移动端红包雨功能页面
2021/01/10 Javascript
[01:02:02]DOTA2上海特级锦标赛A组败者赛 EHOME VS CDEC第二局
2016/02/25 DOTA
[03:48]DOTA2完美大师赛主赛事第二日精彩集锦
2017/11/24 DOTA
老生常谈python函数参数的区别(必看篇)
2017/05/29 Python
python获取程序执行文件路径的方法(推荐)
2018/04/26 Python
对python多线程中Lock()与RLock()锁详解
2019/01/11 Python
HTML5仿手机微信聊天界面
2016/03/18 HTML / CSS
解析HTML5中的新功能本地存储localStorage
2016/03/01 HTML / CSS
荷兰领先的百货商店:De Bijenkorf
2018/10/17 全球购物
zooplus波兰:在线宠物店
2019/07/21 全球购物
新媒传信软件测试面试题
2013/02/24 面试题
旅游项目开发策划书
2014/01/18 职场文书
农业开发项目建议书
2014/05/16 职场文书
动漫设计与制作专业推荐信
2014/07/07 职场文书
2014普法依法治理工作总结
2014/12/18 职场文书
会计工作态度自我评价
2015/03/06 职场文书
详解缓存穿透击穿雪崩解决方案
2021/05/28 Redis
Python合并多张图片成PDF
2021/06/09 Python