zoukankan      html  css  js  c++  java
  • 自定义指令 限制input 的输入位数

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>限制input输入的位数</title>
    </head>
    <body>
          <div id="app">
             <input type="text"   v-split.5="msg"/>
          </div>
    </body>
    <script src="./node_modules/vue/dist/vue.js"></script>  
    <script>
        //设置input 的输入位数
      Vue.directive('split',{
          update(el,bindings,vnode) {
                console.log(bindings);
                let [,len]  = bindings.rawName.split('.');
                console.log(len)
                let ctx = vnode.context;  //msg
                el.addEventListener('input',(e)=>{
                    let  val  =  e.target.value.slice(0,len);
                    ctx[bindings.expression]=val;
                    el.value = val;
                })
                //默认值
                el.value=ctx[bindings.expression];
          },
          bind(el,bindings,vnode) {
               let ctx = vnode.context;  //msg
               let [,len]  = bindings.rawName.split('.');
                el.addEventListener('input',(e)=>{
                    let  val  =  e.target.value.slice(0,len);
                    ctx[bindings.expression]=val;
                    el.value = val;
                })
                 //默认值
                 el.value=ctx[bindings.expression];
          }

      })
      let vm = new Vue({
          el:"#app",
          data() {
             return {
                 msg:'a'
             }
          }
      })
    </script>
    </html>
     
     
     
     
    el,bindings,vnode
     
    el表示 html 元素
    bindings 表示绑定的元素上的属性
    vnode 表示绑定元素的虚拟node
  • 相关阅读:
    vue-cli3 set vue.config.js
    oracle 基本查询语句及实例
    输出流啊输入流
    java线程
    sql基础
    抽象类和接口
    重载和重写的区别
    简单的java面向对象计算器
    运算符的优先级
    隐式类型转换规则
  • 原文地址:https://www.cnblogs.com/guangzhou11/p/11565198.html
Copyright © 2011-2022 走看看