2019-08-22 14:41:07 +08:00
|
|
|
import { debounce, observerDomResize } from '../util/index'
|
|
|
|
|
|
|
|
export default {
|
|
|
|
data () {
|
|
|
|
return {
|
|
|
|
dom: '',
|
|
|
|
|
|
|
|
width: 0,
|
|
|
|
height: 0,
|
|
|
|
|
|
|
|
debounceInitWHFun: '',
|
|
|
|
|
|
|
|
domObserver: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
async autoResizeMixinInit () {
|
|
|
|
const { initWH, getDebounceInitWHFun, bindDomResizeCallback, afterAutoResizeMixinInit } = this
|
|
|
|
|
|
|
|
await initWH(false)
|
|
|
|
|
|
|
|
getDebounceInitWHFun()
|
|
|
|
|
|
|
|
bindDomResizeCallback()
|
|
|
|
|
|
|
|
if (typeof afterAutoResizeMixinInit === 'function') afterAutoResizeMixinInit()
|
|
|
|
},
|
|
|
|
initWH (resize = true) {
|
|
|
|
const { $nextTick, $refs, ref, onResize } = this
|
|
|
|
|
|
|
|
return new Promise(resolve => {
|
2020-09-09 17:20:28 +08:00
|
|
|
$nextTick(_ => {
|
2019-08-22 14:41:07 +08:00
|
|
|
const dom = this.dom = $refs[ref]
|
|
|
|
|
2020-08-25 18:26:29 +08:00
|
|
|
this.width = dom ? dom.clientWidth : 0
|
|
|
|
this.height = dom ? dom.clientHeight : 0
|
|
|
|
|
|
|
|
if (!dom) {
|
|
|
|
console.warn('DataV: Failed to get dom node, component rendering may be abnormal!')
|
|
|
|
} else if (!this.width || !this.height) {
|
|
|
|
console.warn('DataV: Component width or height is 0px, rendering abnormality may occur!')
|
|
|
|
}
|
2019-08-22 14:41:07 +08:00
|
|
|
|
|
|
|
if (typeof onResize === 'function' && resize) onResize()
|
|
|
|
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
getDebounceInitWHFun () {
|
|
|
|
const { initWH } = this
|
|
|
|
|
|
|
|
this.debounceInitWHFun = debounce(100, initWH)
|
|
|
|
},
|
|
|
|
bindDomResizeCallback () {
|
|
|
|
const { dom, debounceInitWHFun } = this
|
|
|
|
|
|
|
|
this.domObserver = observerDomResize(dom, debounceInitWHFun)
|
|
|
|
|
|
|
|
window.addEventListener('resize', debounceInitWHFun)
|
|
|
|
},
|
|
|
|
unbindDomResizeCallback () {
|
|
|
|
let { domObserver, debounceInitWHFun } = this
|
|
|
|
|
2020-08-25 18:26:29 +08:00
|
|
|
if (!domObserver) return
|
|
|
|
|
2019-08-22 14:41:07 +08:00
|
|
|
domObserver.disconnect()
|
|
|
|
domObserver.takeRecords()
|
|
|
|
domObserver = null
|
|
|
|
|
|
|
|
window.removeEventListener('resize', debounceInitWHFun)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted () {
|
|
|
|
const { autoResizeMixinInit } = this
|
|
|
|
|
|
|
|
autoResizeMixinInit()
|
|
|
|
},
|
|
|
|
beforeDestroy () {
|
|
|
|
const { unbindDomResizeCallback } = this
|
|
|
|
|
|
|
|
unbindDomResizeCallback()
|
|
|
|
}
|
|
|
|
}
|