const types = { map: { unload: 'clearMap' }, control: { unload: 'removeControl' }, layer: { unload: 'removeLayer' }, features: { unload: 'removeFeatures' }, listener: { unload: 'removeListener' } } const getParent = $component => ($component.abstract || $component.$el === $component.$children[0].$el) ? getParent($component.$parent) : $component // function destroyInstance () { // const { unload, renderByParent, $parent } = this // if (renderByParent) { // $parent.reload() // } // unload() // } class Mixin { constructor (prop) { this.methods = { ready () { const $parent = getParent(this.$parent) const map = this.map = $parent.map this.load() this.$emit('ready', { map }) }, transmitEvent (e) { this.$emit(e.type.replace(/^on/, ''), e) }, reload () { this && this.$nextTick(() => { this.unload() this.$nextTick(this.load) }) }, unload () { const { map, originInstance } = this try { switch (prop.type) { case 'search': return originInstance.clearResults() case 'autoComplete': case 'lushu': return originInstance.dispose() case 'markerClusterer': return originInstance.clearMarkers() default: map[types[prop.type].unload](originInstance) } } catch (e) { console.log(e) } } } this.computed = { renderByParent () { return this.$parent.preventChildrenRender } } this.mounted = function () { console.log('common mounted') const $parent = getParent(this.$parent) const map = $parent.map const { ready } = this console.log(map) map ? ready() : $parent.$on('onload', ready) } } } export default type => new Mixin({ type })