el-select如何自定义下拉选项框的宽度

简介: el-select如何自定义下拉选项框的宽度


背景

默认情况下,el-select的下拉选项框的宽度会依据选项内容的长度而改变,当选项内容的长度过长的时候,下拉选项框的宽度也会变得很长,甚至可能会超出屏幕宽度,如下图所示:

解决办法

为了解决这一问题,我们可以通过给el-select添加focus事件的监听,当focus之后,动态改变el-option的宽度

<template>
  <div>
  <el-select v-model="textCaseType" placeholder="请选择语料素材类型" class="text-case-type-select" @focus="setOptionWidth">
       <el-option
         v-for="item in textCaseTypeOptions"
         :key="item.value"
         :label="item.label"
         :value="item.value">
        </el-option>
     </el-select>
  </div>
</template>
<script>
export default {
  name: 'CustomizeCreateVideo',
  components: {
  },
  props: {
  },
  data() {
    return {
      textCase: null,
      textCaseOptions: [{
        voice: 'aixia',
        label: 'aaaaaaaaaaaaaaaaaaaaaaaaasssssssssssssssssssssssssssssssssssssssqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqffffffffffffffffffffff',
        speechRate: -146,
        pitchRate: -7,
        volume: 80,
      }, {
        voice: 'xiaoxian',
        label: 'aaaaaaaaaaaaaaaaaaaaaaaaasssssssssssssssssssssssssssssssssssssssqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqffffffffffffffffffffff',
        speechRate: -135,
        pitchRate: 5,
        volume: 70,
      }, {
        voice: 'maoxiaomei',
        label: 'a啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊',
        speechRate: -125,
        pitchRate: 5,
        volume: 80,
      }, {
        voice: 'stanley',
        label: 'Stanley-沉稳男声',
        speechRate: -80,
        pitchRate: 10,
        volume: 80,
      }, {
        voice: 'ailun',
        label: '艾伦-悬疑解说',
        speechRate: -100,
        pitchRate: 3,
        volume: 80,
      }],
      selectOptionWidth: null,
    };
  },
  created() {
  },
  methods: {
    // 下拉框弹出时,设置弹框的宽度
    setOptionWidth(event){
      this.$nextTick(() => {
        this.selectOptionWidth = event.srcElement.offsetWidth + "px";
      }); 
    }
  },
};
</script>

目录
相关文章
|
前端开发
element ui el-table 多选 表头全选框替换文字
element ui el-table 多选 表头全选框替换文字
1642 0
|
6月前
|
JavaScript
Element_select 选择器 选中框中显示不了选中的值
解决Vue中`el-select`选择器不显示选中值的问题:在`selectChanged`方法中添加`this.$forceUpdate()`,强制组件更新,使输入框显示选择的值。示例代码包括模板和方法。
893 2
|
4月前
Element UI【级联选择器】el-cascader 获取选中内容的 label 数据,鼠标悬浮显示超长内容
Element UI【级联选择器】el-cascader 获取选中内容的 label 数据,鼠标悬浮显示超长内容
640 3
|
4月前
el-input实现后缀图标和clearable的兼容,调整el-input clearable与自定义图标展示位置问题
el-input实现后缀图标和clearable的兼容,调整el-input clearable与自定义图标展示位置问题
198 1
|
4月前
Element UI 多选表格--判断勾选数据行的 Checkbox 时为选中还是取消选中
Element UI 多选表格--判断勾选数据行的 Checkbox 时为选中还是取消选中
50 1
|
前端开发
input框点击时去掉默认的外层边框
input框点击时去掉默认的外层边框
58 0
通过select下拉框里的value控制div显示与隐藏
通过select下拉框里的value控制div显示与隐藏
80 0
vxe-table可编辑状态默认显示下拉选select为默认展示
vxe-table可编辑状态默认显示下拉选select为默认展示
|
缓存 JavaScript 前端开发
el-table 列的动态显示与隐藏
当我们在对表格数据查看的时候,可能某些列的数据是当前想要重点关注的,而某些列并不需要展示出来,我们就可以通过对表格的列进行实时的一个切换去实现动态的显示与隐藏。