使用el-select的时候,下拉框滚动弹框消失

1、问题描述
在使用el-select的时候,经常遇见下拉框里要放多个值,比如:文字描述(统计) 例:人数(100),然后文字描述超出隐藏,所有我们就会在el-select内部加入东西
 

<el-select v-model="value" size="small">
    <el-option
		v-for="(item,index) in list"
		:key="item.value"
		:label="item.label"
      	:value="item.value">
      	<div class="flex alignCenter">
      		<span class="label p_nowrap">{{item.label}}</span>
      		<span class="total" >
      			{{' (' + item.total + ')'}}
      		</span>
      	</div>
	</el-option>
</el-select>

看着毫无问题,但是当下拉框出现时,无法进行滚动,滚动下拉框就消失
2、解决方案
 

<el-select v-model="value" size="small">
    <el-option
		v-for="(item,index) in list"
		:key="item.value"
		:label="item.label"
      	:value="item.value">
      	<span class="label p_nowrap">{{item.label}}</span>
      	<span class="total" >
      		{{' (' + item.total + ')'}}
      	</span>
      	</div>
	</el-option>
</el-select>

解决方案就是将el-option内部的div去掉换成span,具体因为啥,我没有细细研究,可能是elementui的版本BUG

### 关于 `el-select` 下拉框滚动条显示后立即消失的问题 当遇到 `el-select` 的下拉框滚动过程中滚动条瞬间显示然后消失的情况,这通常是因为默认行为导致的渲染问题。一种有效的解决方案是在组件中加入特定属性来调整其行为。 通过设置 `:reserve-keyword="false"` 属性可以防止输入失去焦点清空关键词,从而保持搜索状态的一致性[^1]。然而针对滚动条的具体表现,更直接的方法是修改 `el-select` 组件的行为方式以及样式处理逻辑: #### 修改 Popper 配置 为了确保下拉列表能够正确地跟随父级容器移动而不被遮挡或移除,可以通过配置 `popper.js` 来控制出层的位置和附加目标。具体来说,使用`:popper-append-to-body="false"` 可以让下拉菜单不再追加到 body 上而是作为当前元素的子节点存在,这样就可以更好地继承父级样式的上下文环境[^4]。 ```html <template> <el-select :popper-append-to-body="false"> <!-- options --> </el-select> </template> <style scoped> .el-select .el-scrollbar__wrap { overflow-x: hidden; } </style> ``` 上述代码片段中的 CSS 样式用于隐藏水平方向上的溢出部分,避免不必要的横向滚动条干扰用户体验;同通过禁用自动将 popper 添加至 document.body 中的方式解决了因页面布局变化引起的选择器定位偏移的问题。 另外,在某些情况下,如果仍然存在问题,则可能需要进一步调查是否存在其他 JavaScript 或者架层面的影响因素影响到了事件循环机制下的 DOM 更新过程。此建议检查是否有自定义指令或者其他插件对原生组件进行了重写或是扩展操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值