普通电脑可以做网站服务器,旅游+网站建设,就有公司域名怎么建设网站,免费注册邮箱问题描述
Vue2 项目在使用 el-select 组件时#xff0c;动态将disabled变更为了 true#xff0c;元素的高度发生了变化。
问题原因
通过浏览器开发人员工具面板#xff0c;发现#xff0c;组件内的 input 元素被动态设置了height的样式#xff1a;
在项目中检查后并…问题描述
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-uiconst elSelectWatcherSelectDisabled ElementUI.Select.watch.selectDisabled
ElementUI.Select.watch.selectDisabled function () {if (this.multiple) {elSelectWatcherSelectDisabled()}
}Vue.use(ElementUI)