zoukankan      html  css  js  c++  java
  • 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输入框一样。

  • 相关阅读:
    IP 排序
    React 项目搭建
    Nuxt
    element table 封装
    iviewui Slider 滑块的坑
    浏览器自动填写用户名和密码
    asd
    正则表达式
    snmp中载入第三方mib库(转载)
    一键lamp
  • 原文地址:https://www.cnblogs.com/fqh123/p/14988487.html
Copyright © 2011-2022 走看看