1. 程式人生 > 其它 >el-select選擇框寬度與輸入框相同

el-select選擇框寬度與輸入框相同

// 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輸入框一樣。