zoukankan      html  css  js  c++  java
  • VUE 实现IP输入框

    <style>
            .ipAdress {
                display: flex;
                align-items: center;
                border: 1px solid #0190FE;
                width: 148px;
                margin-right: 10px;
                padding: 0;
            }
    
            .ipAdress li {
                position: relative;
                height: 23px;
                margin: 0;
                list-style: none;
            }
    
            ul[class="ipAdress"] input[type="text"] {
                border: none;
                width: 100%;
                height: 23px;
                text-align: center;
                background: transparent;
                color: #000;
            }
    
            .ipAdress li div {
                position: absolute;
                bottom: 2px;
                right: 0;
                border-radius: 50%;
                background: #0190FE;
                width: 2px;
                height: 2px;
            }
    
            /*只需要3个div*/
            .ipAdress li:last-child div {
                display: none;
            }
    
            /*取消掉默认的input focus状态*/
            .ipAdress input:focus {
                outline: none;
            }


    <div id="app">
            <ul class="ipAdress">
                <li v-for="(item,index) in ipAdress">
                    <input type="text" @input="checkIpVal(item,index)" @keyup="turnIpPOS(item,index,$event)"
                        v-model:value="item.value" ref="ipInput" @blur="setDefaultVal(item)" />
                    <div></div>
                </li>
            </ul>
    </div>
     
    //vue实例 data
    ipAdress: [{
                        value: ''
                    }, {
                        value: ''
                    }, {
                        value: ''
                    }, {
                        value: ''
                    }]
    //methods
                    checkIpVal(item, index) {
                        let self = this;
                        //确保每个值都处于0-255
                        let val = item.value;
                        //当输入的是空格时,值赋为空
                        val = val.trim();
                        val = parseInt(val, 10);
                        if (isNaN(val)) {
                            val = ''
                        } else {
                            val = val < 0 ? 0 : val;
                            val = val > 255 ? 255 : val;
                        }
                        item.value = val;
                    },
                    turnIpPOS(item, index, event) {
                        let self = this;
                        let e = event || window.event;
                        // console.log(index);
                        //删除键把当前数据删除完毕后会跳转到前一个input,左一不做任何处理
                        if (e.keyCode == 8) {
                            let val = item.value;
                            console.log(val);
                            if (index == 0) { } else if(val==''){
                                self.$refs.ipInput[index - 1].focus();
                            }
                        }
                        //右箭头、回车键、空格键、冒号均向右跳转,右一不做任何措施
                        if (e.keyCode == 39 || e.keyCode == 13 || e.keyCode == 32 || e.keyCode == 190 || e.keyCode == 110) {
                            if (index == 3) { } else {
                                self.$refs.ipInput[index + 1].focus();
                            }
                        }
                    },
                    setDefaultVal(item) {
                        //当input失去焦点,而ip没有赋值时,会自动赋值为0
                        let self = this;
                        let val = item.value;
                        if (val == '') {
                            item.value = '0';
                        }
                    },

  • 相关阅读:
    PHP全路径无限分类原理
    SecureCRT上传bash: rz: command not found
    Android利用Fiddler进行网络数据抓包【怎么跟踪微信请求】
    Creating the Help Page in ASP.NET Web API
    Windows上怎么安装ELK
    安装ELK
    How to kill a process on a port on linux 怎么杀死 关掉一个端口
    How to install Mysql in the CentOS
    Hadoop: Setup Maven project for MapReduce in 5mn
    Install Ambari 2.2.0 from Public Repositories(Hadoop)
  • 原文地址:https://www.cnblogs.com/sheep-fu/p/14368978.html
Copyright © 2011-2022 走看看