el-input设置后缀显示单位并阻止滚轮微调

项目中收集form表单信息时,有时会需要在el-input后面显示单位,效果如图:

当然,我们可以直接在输入框后面加上单位,但直接给输入框上加单位不管是视图上还是用户体验上看起来都要好一点

element-plus / element-ui给我们提供了对应插槽

图中效果显然是尾部内容,因此只需要使用suffix插槽即可实现该效果

c 复制代码
<el-input v-model='data'>
	<template #suffix>元</template>
</el-input>

这里我要提一个额外的内容,由于我这里收集的是数字,因此我给el-input设置了type='number',但总是不知道什么情况,有时输入框中的数值比我输入的有细微出入

其实,后来无意间发现是输入框的滚轮滚动事件,一般给el-input添加了type='number'后,输入框后面会出现上下两个箭头可以对数值进行微调。

如果鼠标光标在输入框内并聚焦时,滚动滚轮也会微调数值,因此我就出现了这个问题,输入完数值,此时鼠标还聚焦在输入框内,滚动滚轮(因为我填写内容较多这个页面有滚动条需要滚动到上方/下方去填写别的内容),此时我输入框中的数值就会因为我滚动滚轮进行了微调,出现数值与输入的数值不一致

解决方法,就是阻止el-input滚轮事件的默认行为

c 复制代码
<template>
<el-input v-model='data' @wheel='preventScroll'>
	<template #suffix>元</template>
</el-input>
</template>
<script>
export default {
	data(){
		return {
			data
		}
	},
	methods:{
		preventScroll(e){
			e.preventDefault()
		}
	}
}
</script>

这里还有一点是我不需要上下箭头的微调,所以用css样式将上下箭头隐藏掉,给el-input设置类名no-controls,代码如下:

:deep.no-controls input::-webkit-inner-spin-button,

:deep.no-controls input::-webkit-outer-spin-button{

-webkit-appearance: none !important;

}

:deep.no-controls inputtype="number"{

-moz-appearance: textfield;

}

相关推荐
aa小小25 分钟前
localhost 访问异常排查笔记
前端
格子软件26 分钟前
2026年GEO优化系统源码的分布式状态机深度拆解
java·前端·vue.js·vue·geo
陈随易1 小时前
Rust、Golang、MoonBit 编译成 WASM,体积和速度差距有多大?
前端·后端·程序员
IT_陈寒1 小时前
Python多线程的坑,我居然现在才踩到
前端·人工智能·后端
格子软件1 小时前
2026年GEO优化系统源码解构:核心状态机与高并发流控深度剖析
java·vue.js·spring boot·vue·geo
触底反弹2 小时前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法
竹林8182 小时前
从 RPC 超时到批量签名:我用 @solana/web3.js 重构了一个 NFT 铸造页面,踩了这些坑
前端·javascript
工业HMI实战笔记2 小时前
工业HMI界面布局“1核2辅”黄金结构,适配90%场景
前端·ui·性能优化·自动化·交互
林希_Rachel_傻希希3 小时前
web性能优化之————图片效果
前端·javascript·面试
Darling噜啦啦3 小时前
前端存储与 this 指向完全指南:从 LocalStorage 实战到 call/apply/bind 深度解析
前端·javascript