zoukankan      html  css  js  c++  java
  • 【vue】vue +element 搭建项目,el-input 常用的验证

    1.el-input 常用布局

    <el-input class="filter-item dialog-search" size="small" 
        @keyup.enter.native="searchBtn" 
        v-model.lazy.trim="searchKey" 
       @change="check"
      placeholder="请输入关键字" > <el-button slot="append" icon="el-icon-search" @click.native="searchBtn"></el-button>
    </el-input>

    2.input的限制条件

    ①只能输入大于0的整数

    check(value) {
        let reg = /^[1-9]d*$/;
        var _this = this;
        if (value) {
            if (new RegExp(reg).test(value) == false) {
                setTimeout(() => {
                    _this.actionDataForm.studNum = '';
                   _this.errorTip = true;
            }, 500); }

    else {
          
    this.errorTip = false;
        }
    }
    },

    form表单验证中只能输入整数(方法一)

    布局:

    <el-form-item label="充值余额:" prop="charge_money" >
      <el-input placeholder="1-999999" size="small" v-model.number ="ruleForm.charge_money" @input="computedBalance" style=" 238px;"></el-input></el-form-item>

    js:

    var checkBalance = (rule, value, callback) => {
        if (!value) {
            return callback(new Error('充值余额不能为空'));
        }
        setTimeout(() => {
            if (!Number.isInteger(value)) {
                callback(new Error('请输入数字值'));
            } else {
                if (Number(value) > 999999) {
                    callback(new Error('请输入1-999999的数字'));
                } else {
                    callback();
                }
            }
        }, 1000);
    };

    form表单验证中只能输入整数(方法二,麻烦)

    布局:

    <el-form-item label="充值余额:" prop="charge_money" >
      <el-input placeholder="1-999999" size="small" v-model ="ruleForm.charge_money" @input="computedBalance" style=" 238px;"></el-input></el-form-item>

    js:

    var checkBalance = (rule, value, callback) => {
        let reg = /^[1-9]d*$/;  //整数
        let reg2 = /^[1-9]d*.d*|0.d*[1-9]d*$/;  //小数
        if (!value) {
            return callback(new Error('充值余额不能为空'));
        }
        setTimeout(() => {
            if (!reg.test(value)) {
                if (reg2.test(value)) {
                    callback(new Error('请输入整数'));
                } else {
                    callback(new Error('请输入符合规则的数字'));
                }
            } else if (Number(value) > 999999) {
                callback(new Error('请输入1-999999的数字'));
            } else {
                callback();
            }
        }, 1000);
    };

    ②只能输入数字(整数,浮点数)

    check() {
        let reg = /[^d.]/g;
        if (this.searchKey && new RegExp(reg).test(this.searchKey)) {//非数字
            this.$message({
                message: '请输入正确的数字',
                type: 'warning'
            })
            return;
        }
        ...
        ...
    },

    ③手机号验证

    checkMobile (number) {
        var partten = /^(13[0-9]|14[0-9]|15[0-9]|16[6]|18[0-9]|19[6,9]|17[0-9])d{8}$/i;
        return partten.test(number);
    },

    ④邮箱验证

    var checkEmail = (rule, value, callback) => {
        if (!value) {
            return callback();
        }
        if (value) {
            setTimeout(() => {
                var reg = /^([a-zA-Z0-9]+[_|\_|.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|.]?)*[a-zA-Z0-9]+.[a-zA-Z]{2,3}$/;
                if (!reg.test(value)) {
                    callback(new Error('请输入有效的电子邮箱!'));
                } else {
                    callback();
                }
              }, 500);
          }
    }

    ⑤将输入框的内容全角转为半角

    var ToCDB = function(str){ 
        var tmp = ""; 
        for(var i=0;i<str.length;i++) 
        { 
            if(str.charCodeAt(i)>65248&&str.charCodeAt(i)<65375) 
            { 
                tmp += String.fromCharCode(str.charCodeAt(i)-65248); 
            }else { 
                tmp += String.fromCharCode(str.charCodeAt(i)); 
            } 
        } 
        return tmp 
    }    

    ⑥名称字数限制(30个中文字符长度)

    nameLimt (){
        var reg = /[!@#$%^&*??/\“::;~+]/;
        this.companyName = this.companyName.replace(reg,'')    ;
        var GetLength = function (str) {
            //获得字符串实际长度,中文2,英文1
            var realLength = 0, len = str.length, charCode = -1;
            for (var i = 0; i < len; i++) {
                charCode = str.charCodeAt(i);
                if (charCode >= 0 && charCode <= 128) realLength += 1;
                else realLength += 2;
            }
          return realLength;
        };
        
         /** 
        * js截取字符串,中英文都能用 
        * @param str:需要截取的字符串 
        * @param len: 需要截取的长度 
        */
        var cutstr = function(str, len) {
            var str_length = 0;
            var str_len = 0;
            var str_cut = new String();
             str_len = str.length;
            for (var i = 0; i < str_len; i++) {
                var temp = str.charAt(i);
                str_length++;
                if (escape(temp).length > 4) {//中文字符的长度经编码之后大于4  
                    str_length++;
                }
                str_cut = str_cut.concat(temp);
                if (str_length >= len) {
                 return str_cut;
             }
           }
                
            //如果给定字符串小于指定长度,直接返回  
             if (str_length < len) {
               return str;
          }
        }
            
        if(GetLength(this.companyName) > 60){
            this.companyName = cutstr(this.companyName, 60);
            return;
        }
            
    }    

     ⑦只能输入正整数和负整数

    let reg = /^(0|[1-9][0-9]*|-[1-9][0-9]*)$/;

    ⑧以字符开头只能输入数字、字母、下划线

    let reg = /^[a-zA-Z][a-zA-Z0-9_]*$/

    ⑨只取字符中的数字

    var  str= '<ww-open-id type="departmentName" openid="12346"></ww-open-id>';
    console.log(str.replace(/[^0-9]/ig,''))

    3.el-input 和el-form一起使用时验证范例

    export default {
        data() {
            var checkEmail = (rule, value, callback) => {
                if (!value) {
                    return callback();
                }
                if (value) {
                    setTimeout(() => {
                        var reg = /^([a-zA-Z0-9]+[_|\_|.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|.]?)*[a-zA-Z0-9]+.[a-zA-Z]{2,3}$/;
                        if (!reg.test(value)) {
                            callback(new Error('请输入有效的电子邮箱!'));
                        } else {
                            callback();
                        }
                    }, 500);
                }
            };
    
            return {
                ruleForm: {
                    name: '',
                    email: '',
                },
                rules: {
                    name: [
                        {required: true, message: '请输入姓名', trigger: 'blur'},
                        {min: 1, max: 15, message: '长度在 15 个字以内', trigger: 'blur'}
                    ],
                    email: [
                        {validator: checkEmail, trigger: ['blur,change']}
                    ],
    
                },
            };
        },
    }    

     4.Event

    实时输入使用 @input

     

    作者:smile.轉角

    QQ:493177502

  • 相关阅读:
    github 访问速度慢 的解决+个人理解
    phpstorm 编辑器进行自动的注释添加
    输入框只能输入数字(最好用)
    数组去重(根据对象属性去重)
    mac安装Homebrew和 tree
    vue中 .sync 的作用
    打包 vue 组件为 webcomponent
    Android开发之SharedPreferences
    Android开发之SharedPreferences扩展以及File
    Android 开发之SQLite基础
  • 原文地址:https://www.cnblogs.com/websmile/p/8650930.html
Copyright © 2011-2022 走看看