• 自定义指令 限制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
  • 相关阅读:
    ASP记数器
    Photoshop压缩png图片方法之一
    Drupal的高速缓存配置APC
    各种share button
    兼容iphone、ipad与PC平台的在线视频
    知识组织方法总结
    Virtuemart2 for joomla2.5
    joomla2.5 常用组件
    网上找来经过改良的多级联动下拉菜单
    joomla组件开发中的时区问题
  • 原文地址:https://www.cnblogs.com/guangzhou11/p/11565198.html
Copyright © 2020-2023  润新知