正则表达验证公用类

import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * <p>作者: 沈晨辉
 * <p>邮箱: shenchenhui@vaneqi.com
 * <p>日期: 2016年11月18日
 * <p>描述: 正则表达验证公用类
 */
public class RegexUtil {
    /**
     * 是否是数字
     *
     * @param bit 小数位数
     */
    public static boolean isNumber(String src, int bit) {
        Pattern pattern = Pattern.compile("^(([1-9]{1}\\d*)|([0]{1}))(\\.(\\d){0," + bit + "})" +
                "?$"); // 判断小数点后2位的数字的正则表达式
        Matcher match = pattern.matcher(src);

        if (match.matches() == false) {
            return false;
        } else {
            return true;
        }
    }

    /**
     * 大陆手机号码11位数,匹配格式:前三位固定格式+后8位任意数
     * 此方法中前三位格式有:
     * 13+任意数
     * 15+除4的任意数
     * 18+任意数
     * 17+除9的任意数
     * 147
     */
    public static boolean isChinaPhoneLegal(String str) {
        /*String regExp = "^((13[0-9])|(15[^4])|(166)|(17[0-9])|(18[0-9])|(19[8-9])|(147,145))" +
                "\\d{8}$";*/
        String regExp = "1[0-9][0-9]{9}";
        Pattern p = Pattern.compile(regExp);
        Matcher m = p.matcher(str);
        return m.matches();
    }

    /**
     * 是否是合法的电话号码
     */
    public static boolean isTelLegal(String str) {
        String regExp = "(^(([0\\+]\\d{2,3}-)?(0\\d{2,3})-)?(\\d{7,8})(-(\\d{3,}))?$)|(^0{0," +
                "1}1[0-9]{10}$)";
        Pattern p = Pattern.compile(regExp);
        Matcher m = p.matcher(str);
        return m.matches();
    }

    /**
     * 是否是合法的电子邮箱
     */
    public static boolean isEmailLegal(String str) {
        String regExp = "^([a-z0-9A-Z]+[-|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)" +
                "+[a-zA-Z]{2,}$";
        Pattern p = Pattern.compile(regExp);
        Matcher m = p.matcher(str);
        return m.matches();
    }

    /**
     * 将string去掉内部空格
     *
     * @param src 原文本
     * @param chr 需要清除的字符
     */
    public static String stringDropSpace(String src, char[] chr) {
        StringBuilder ret = new StringBuilder();

        for (int i = 0; i < src.length(); i++) {
            char c = src.charAt(i);
            boolean flag = false;
            for (int j = 0; j < chr.length; j++) {
                if (chr[i] == c) {
                    flag = true;
                    break;
                }
            }
            if (flag == false)
                ret.append(c);
        }

        return ret.toString();
    }

    /**
     * 是否是合法的账号
     */
    public static boolean isAccountLegal(String str) {
        String regExp = "^[a-zA-Z]\\w{5,17}$";
        Pattern p = Pattern.compile(regExp);
        Matcher m = p.matcher(str);
        return m.matches();

    }

    /**
     * 是否是合法的密码
     */
    public static boolean isPassLegal(String str) {
        /*String regExp = "^(?![0-9]+$)(?![a-z]+$)(?!\\d+$)(?![\\W_]+$)\\S{6,16}$";
        Pattern p = Pattern.compile(regExp);
        Matcher m = p.matcher(str);*/
        return str.length() > 5 ? true : false;
    }

    /**
     * 判断字符串是否全部为中文字符组成
     *
     * @param str 检测的文字
     * @return true:为中文字符串,false:含有非中文字符
     */
    public static boolean isChineseStr(String str) {
        String regExp = "^[\\u4e00-\\u9fa5]+(·[\\u4e00-\\u9fa5]+)*$";
        Pattern p = Pattern.compile(regExp);
        Matcher m = p.matcher(str);
        return m.matches();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue 2.0中,可以使用element-ui组件库中的MessageBox和InputNumber组件来实现带有正则表达验证的输入框。 首先,我们需要引入element-ui组件库。在Vue项目中使用element-ui可以通过npm安装: ``` npm install element-ui -S ``` 然后在main.js中引入并注册: ``` import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI) ``` 接下来,我们来看一下如何在MessageBox中实现带有正则表达验证的输入框: ``` this.$prompt('请输入内容', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', inputPattern: /^[a-zA-Z0-9]{6,20}$/, // 正则表达验证 inputErrorMessage: '请输入6-20位字母或数字' // 验证不通过的提示信息 }).then(({ value }) => { // 处理输入的内容 }).catch(() => { // 取消输入 }) ``` 在上面的代码中,我们使用了MessageBox的prompt方法,它接受三个参数:提示信息、提示框标题、配置项。其中,配置项中的inputPattern和inputErrorMessage分别用于设置正则表达验证验证不通过的提示信息。 接下来,我们来看一下如何在InputNumber中实现带有正则表达验证的输入框: ``` <el-input-number v-model="number" :min="1" :max="100" :precision="0" :formatter="formatNumber" :parser="parseNumber"></el-input-number> ``` 在上面的代码中,我们使用了InputNumber组件,并且通过v-model指令绑定了一个number变量来实现双向数据绑定。同时,我们使用了min、max、precision、formatter和parser等属性来进行配置。其中,formatter和parser属性用于设置格式化和解析函数,可以在这里实现正则表达验证: ``` export default { data() { return { number: 0 } }, methods: { formatNumber(value) { // 格式化函数,将数字转换为字符串 return String(value) }, parseNumber(value) { // 解析函数,将字符串转换为数字,并进行正则表达验证 const reg = /^[1-9]\d*$/ if (reg.test(value)) { const num = parseInt(value, 10) if (num >= 1 && num <= 100) { return num } } return this.number } } } ``` 在上面的代码中,我们通过formatter和parseNumber方法实现了将数字转换为字符串和将字符串转换为数字的功能,并在parseNumber方法中进行了正则表达验证。如果验证不通过,我们返回之前的数字,并保持输入框的值不变。 综上所述,以上就是在Vue 2.0中使用MessageBox和InputNumber组件实现带有正则表达验证的输入框的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值