问题描述
Vue2 项目在使用 el-select 组件时,动态将disabled
变更为了 true
,元素的高度发生了变化。
问题原因
通过浏览器开发人员工具面板,发现,组件内的 input
元素被动态设置了height
的样式:
在项目中检查后并没有找到触发这个设置的代码,所以怀疑是组件自身的逻辑。
于是找到 ElSelect 的源码(node_modules\element-ui\packages\select\src\select.vue
),果然发现有一个方法里进行了 height
的设置:
resetInputHeight() {
if (this.collapseTags && !this.filterable) return;
this.$nextTick(() => {
if (!this.$refs.reference) return;
let inputChildNodes = this.$refs.reference.$el.childNodes;
let input = [].filter.call(inputChildNodes, item => item.tagName === 'INPUT')[0];
const tags = this.$refs.tags;
const tagsHeight = tags ? Math.round(tags.getBoundingClientRect().height) : 0;
const sizeInMap = this.initialInputHeight || 40;
// 这里
input.style.height = this.selected.length === 0
? sizeInMap + 'px'
: Math.max(
tags ? (tagsHeight + (tagsHeight > sizeInMap ? 6 : 0)) : 0,
sizeInMap
) + 'px';
if (this.visible && this.emptyText !== false) {
this.broadcast('ElSelectDropdown', 'updatePopper');
}
});
},
这个方法在 disabled
变更时会触发:
watch: {
selectDisabled() {
this.$nextTick(() => {
this.resetInputHeight();
});
},
...
我的解决办法
这个逻辑可能是为了多选时文本框的高度而设的,因为确认我的项目在单选时不需要考虑高度的变化,所以我直接替换这个监听回调,以解决了我的问题。
import Vue from 'vue'
import ElementUI from 'element-ui'
const elSelectWatcherSelectDisabled = ElementUI.Select.watch.selectDisabled
ElementUI.Select.watch.selectDisabled = function () {
if (this.multiple) {
elSelectWatcherSelectDisabled()
}
}
Vue.use(ElementUI)