-
先决条件,准备一个input和vue项目。这里使用了vue3项目。
html<template> <input> </template> -
先确定自定义指令的编写方式。在setup里面直接编写。
javascript<template> <input v-input> </template> <script setup> const vInput = { mounted(el, binding, vnode) { console.log("222"); } }; </script> -
测试是否有打印出222。我这边是有直接打印的。
-
我们解释一下他的参数 el,binding,vnode都有什么用,这里我们直接使用官网的图片。

-
其中vnode是虚拟节点。
-
在自定义组件中加入输入框的监听事件,使用el加入addEventListener的时间,就可以实现监听到绑定的指令时,输入框的输入的回调。
javascript<template> <input v-input ref="inputRef"> </template> <script setup> const vInput = { mounted(el, binding, vnode) { if (vnode.type != "input") { return; } el.addEventListener('input', (e) => { const data = e.data; }); } }; </script> -
这边可以实现一个需求,输入框只能输入整数。详细的需求是,如果输入的字母,不会添加到结果的后面。输入的字符可以从e.data中获取。
javascriptel.addEventListener('input', (e) => { console.log("e", e.data); )); -
将输入框的输入内容进行存储。将内容存储到oldValue中。
javascriptlet oldValue = ""; el.addEventListener('input', (e) => { if (e.data && !/^\-?\d*\.?\d*$/.test(el.value)) { el.value = oldValue; } oldValue = el.value; }); -
判断输入框的文本是不是实数,如果是,就使用旧值进行赋值。
javascriptconst vInput = { mounted(el, binding, vnode) { if (vnode.type != "input") { return; } let oldValue = ""; el.addEventListener('input', (e) => { if (e.data && !/^\-?\d*\.?\d*$/.test(el.value)) { el.value = oldValue; } oldValue = el.value; }); } }; -
全部代码
javascript<template> <input v-input ref="inputRef"> </template> <script setup> const vInput = { mounted(el, binding, vnode) { if (vnode.type != "input") { return; } let oldValue = ""; el.addEventListener('input', (e) => { if (e.data && !/^\-?\d*\.?\d*$/.test(el.value)) { el.value = oldValue; } oldValue = el.value; }); } }; </script>
编写vue的输入框的自定义指令研究
姚*鸿的博客2024-09-08 13:33
相关推荐
春风得意之时6 分钟前
前端安装项目出现代理问题和ssl认证问题问心无愧051311 分钟前
ctf show web入门109meilindehuzi_a17 分钟前
透视 V8 底部:从物理内存到函数式哲学,重新解构 JavaScript 数组粉末的沉淀20 分钟前
vue:Vite项目中高效管理纯色SVG图标的方案FlyWIHTSKY20 分钟前
JavaScript 和 TypeScript 分别是什么,可以相互写吗卤蛋fg621 分钟前
vxe-table 列宽与行高拖拽调整:让表格布局极其灵活,拖拽功能非常强大YHHLAI22 分钟前
JavaScript 数据结构精讲:数组底层与实战避坑moMo33 分钟前
Promise 的本质:不是异步处理,而是流程控制dotnet9034 分钟前
PDF 页面尺寸上限是 14400。iText 直接加载成功的大图可能超过这个限制,需要在 setPageSize 之前等比缩放。threelab34 分钟前
Three.js 几何图形变换 | 三维可视化 / AI 提示词