先拓企业站
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

71 lines
1.4 KiB

4 months ago
<template>
<span>
<slot>
<input>
</slot>
</span>
</template>
<script>
import commonMixin from '../base/mixins/common.js'
import bindEvents from '../base/bindEvent.js'
export default {
name: 'bm-autocomplete',
mixins: [commonMixin()],
props: {
types: {
type: String
},
location: {
type: String
},
sugStyle: {
type: Object,
default () {
return {}
}
}
},
watch: {
types () {
this.reload()
},
location () {
this.reload()
}
},
methods: {
load () {
const {BMap, map, $el, types, location, sugStyle} = this
const input = $el.querySelector('input')
if (!input) {
return
}
this.originInstance = new BMap.Autocomplete({
input,
types,
location: location || map,
onSearchComplete: e => {
const $sugs = document.querySelectorAll('.tangram-suggestion-main')
for (const $sug of $sugs) {
for (const name in sugStyle) {
$sug.style[name] = sugStyle[name].toString()
}
}
this.$emit('searchcomplete', e)
}
})
// Support v-model
this.originInstance.addEventListener('onconfirm', e => {
const val = e.item.value
this.$emit('input', val.province + val.city + val.district + val.street + val.business)
})
bindEvents.call(this, this.originInstance)
}
}
}
</script>