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)

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM