el-select选择框宽度与输入框相同|事件委托给el-option加title
。
// el-select下拉框宽度与输入框保持一致 document.addEventListener('click',e => { setTimeout(() => { let activeNode = document.activeElement; if(activeNode){ let parentNode = activeNode.parentNode; if(parentNode){ if(parentNode.className.indexOf('is-focus') > -1){ let granpaNode = parentNode.parentNode; if(granpaNode && granpaNode.className.indexOf('el-select') > -1){ // el-select下拉框展开 let inputWidth = parentNode.offsetWidth; setTimeout(() => { let elSelectDropdown = document.querySelectorAll('.el-select-dropdown'); for(let i = 0;i < elSelectDropdown.length; i++){ if(getComputedStyle(elSelectDropdown[i],false)['display'] == 'block'){ let elScrollbarView = elSelectDropdown[i].getElementsByClassName('el-scrollbar__view')[0]; elScrollbarView.style.width = inputWidth + 'px'; } } },1) } } } } },1); },true)
思路:用document.activeElement 找到页面当前活跃元素,找父级几点,判断是否为el-select选择框,根据是否有is-focus类名,判断下拉框是否展开,在全局找到下拉框的所有元素(可能不止一个),从哪个所有的下拉框元素中找到display属性为block的下拉框,设置宽度与当前活跃的el-selct输入框一样。
事件委托,给el-option加title属性
// 下拉框统一加title属性 document.addEventListener('mouseenter',e => { var event = e || window.event; var target = event.target || event.srcElement; if (target.className.indexOf('el-select-dropdown__item') > -1) { target.setAttribute("title", target.children[0].innerHTML); } },true)
。