javascript
import { directive } from 'vue'
const noDecimal = {
mounted(el) {
el.addEventListener('keypress', (e) => {
if (e.key === '.') {
e.preventDefault()
}
})
}
}
// 使用自定义指令
directive('no-decimal', noDecimal)
- 使用 标签上添加
v-no-decimal
javascript
<el-input type="text" v-model="value" v-no-decimal placeholder="请输入..." > </el-input>
v3 指令生命周期
data:image/s3,"s3://crabby-images/b2820/b282028b09568c08c287da10e30f394d0f898d9f" alt=""
v2指令生命周期 官网
vue2中mounted
替换成bind
javascript
directives: {
'no-decimal': {
bind: (el) => {
el.addEventListener('keypress', (event) => {
if (event.key === '.') {
event.preventDefault()
}
})
}
}
},
data:image/s3,"s3://crabby-images/43a6a/43a6a6b658dd0c858e55513cce1d26f513ee3d62" alt=""