使用Jquery validate时写的一些东西,在这里做个笔记

在使用 Jquery validate 的minlength和maxlength进行文本框内容长度验证的时候,对于一个汉字的长度检测结果是1个字符长度,

在这里我想让一个汉字的长度为2个字符长度,下面记录一下实现方法。

首先我们定义一个需求,比如下面文本框,我们想让输入的用户名长度不能超过10个字符(一个汉字为两个字符长度)。

用户名:<input type="text" name="username" id="username ">

然后自定义校验规则,代码如下:

 1 /* 自定义验证规则,内容的最大长度,一个汉字等于两个字符 */
2 $.validator.addMethod("stringMaxLength",function(value,element,params){
3 var length = value.length;
4 for( var i = 0; i < value.length; i++ ) {
5 if( value.charCodeAt(i) > 19967 ) {
6 length++;
7 }
8 }
9 return length>params[0]?false:true;
10 },"最大长度不能超过{0}个字符,一个汉字为两个字符")

上面代码大体结构是这样的:

$.validator.addMethod(rulesName,function,msg)

rulesName:规则的名称,这里是stringMaxLength(自己定义的)

function:是规则的具体实现函数,下面会具体介绍这个函数以及它的三个参数,这里是function(value,element,params)

msg:该规则的校验错误信息,这里是:“最大长度不能超过{0}个字符,一个汉字为两个字符“,这个{0},是什么意思呢?往下看。

1 function(value,element,params) {
2 //这里写校验的具体实现
4 }

它有三个固定参数,value,element,params  (固定参数,固定参数,固定参数,重要的事情说三遍!!!敲黑板了)

结合我们上面的需求,三个参数的含义如下:

value:是我们在文本框中输入的内容,即校验的目标

element:是校验的元素,input这个元素,这里用不到该元素的值(胸弟!忽略它)

params:校验参数(我自己取得名字,哈哈……嗝,我没有具体去查官方的称

它是一个数组,内容是我们设置校验规则时传入的参数,这里我们应该传入参数为10(内容最大长度为10),所以params[0]就是10。

现在回答上面遗留的一问题,就是{0},他在这里其实代表的就是params[0],回答完毕。参数具体怎么传进来,下面就是了。

假设我们上面需求中的文本框所在的form表单的id为login, 检验的具体实现

$.validator.addMethod("stringMaxLength",function(value,element,params){
var length = value.length;
for( var i = 0; i < value.length; i++ ) {
if( value.charCodeAt(i) > 19967 ) {
length++;
}
}
return length>params[0]?false:true;
},"最大长度不能超过{0}个字符,一个汉字为两个字符")

怎么判断是汉字呢,我们是遍历的value,value.charCodeAt(i)返回的是value中对应下标为i的字符的unicode编码,

这个返回值是整数,它的范围是0-65535(10进制),而汉字的unicode编码的范围是19968-40869(10进制)。

所以根据这个范围判断如果是汉字,再在value.length的基础上加1。

下面是使用这个验证规则:

/* 定义表单验证规则 */
$().ready(function(){
$("#login").validate
rules:{
username:{
stringMaxLength:["10"] //参数必须这么传进去,如果想自定义它的校验错误信息,设置方法和其它规则一样
}
}
});
});

以上仅供参考,希望对您有所帮助。

Jquery Validate自定义验证规则,一个汉字等于两个字符长度的更多相关文章

  1. jquery validate 自定义验证方法

    query validate有很多验证规则,但是更多的时候,需要根据特定的情况进行自定义验证规则. 这里就来聊一聊jquery validate的自定义验证. jquery validate有一个方法 ...

  2. jquery validate 自定义验证方法 日期验证

    jquery validate有很多验证规则,但是更多的时候,需要根据特定的情况进行自定义验证规则. 这里就来聊一聊jquery validate的自定义验证. jquery validate有一个方 ...

  3. 扩展jquery.validate自定义验证,自定义提示,本地化

    <!DOCTYPE html> <html> <head> <meta name="viewport" content="wid ...

  4. jquery.validate自定义验证--成功提示与择要提示

    1. 自定义验证--成功提示 1) 添加选项 errorClass: "unchecked", validClass: "checked", errorElem ...

  5. jQuery Validate自定义验证方法实现方式

    对应调用函数: ( 可以在内部写js/或者外部引入-我是外部引入的文件 )  validate.expand.js // JavaScript Document //检测手机号是否正确 jQuery. ...

  6. Jquery validate自定义验证

    http://www.runoob.com/jquery/jquery-plugin-validate.html addMethod(name,method,message)方法 参数 name 是添 ...

  7. Jquery Validate 相关参数及常用的自定义验证规则

    一.官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation 二.默认校验规则 1 2 3 4 5 6 7 8 9 10 1 ...

  8. NET MVC全局异常处理(一) 【转载】网站遭遇DDoS攻击怎么办 使用 HttpRequester 更方便的发起 HTTP 请求 C#文件流。 Url的Base64编码以及解码 C#计算字符串长度,汉字算两个字符 2019周笔记(2.18-2.23) Mysql语句中当前时间不能直接使用C#中的Date.Now传输 Mysql中Count函数的正确使用

    NET MVC全局异常处理(一)   目录 .NET MVC全局异常处理 IIS配置 静态错误页配置 .NET错误页配置 程序设置 全局异常配置 .NET MVC全局异常处理 一直知道有.NET有相关 ...

  9. C#计算字符串长度,汉字算两个字符

    在C#中的字符串类String中,有个Length属性表示字符串的长度,但该字段返回的是字符的个数,如果字符串中含有中文字符的话,一个汉字占用两个字符的长度,此时获取的长度就不够精确,当然也看具体业务 ...

随机推荐

  1. 2.1PyCharm 的初始设置

    PyCharm 的初始设置(知道) 目标 恢复 PyCharm 的初始设置 第一次启动 PyCharm 新建一个 Python 项目 设置 PyCharm 的字体显示 PyCharm 的升级以及其他 ...

  2. 5.1-5 uname、hostname、dmesg、stat、du

    5.1 uname:显示系统信息     uname命令用于显示系统相关信息,比如内核版本号.硬件架构等. -a    显示系统所有相关信息 -v    显示内核版本 -m    显示计算机硬件架构 ...

  3. 如何像如何像 NASA 顶级程序员一样编程 — 10 条重要原则

    https://www.oschina.net/news/90499/nasa-programmer-rule?from=20171112#0-qzone-1-7898-d020d2d2a4e8d1a ...

  4. kubernetes 降本增效标准指南|理解弹性,应用弹性

    弹性伸缩在云计算领域的简述 弹性伸缩又称自动伸缩,是云计算场景下一种常见的方法,弹性伸缩可以根据服务器上的负载.按一定的规则.进行弹性的扩缩容服务器. 弹性伸缩在不同场景下的含义: 对于服务运行在自建 ...

  5. 适用于Linux 2的Windows子系统上的CUDA

    适用于Linux 2的Windows子系统上的CUDA Announcing CUDA on Windows Subsystem for Linux 2 为了响应大众的需求,微软在2020年5月的构建 ...

  6. 狂神说linux笔记:基本操作

    Linux介绍 Linux的概述本文就不赘述了,如果想仔细了解的小伙伴可以百度Linux的历史或者看看狂神的原文.本文主要写linux的操作过程知识点. 狂神的原文如下: https://mp.wei ...

  7. 深入理解Java中的反射机制和使用原理!详细解析invoke方法的执行和使用

    反射的概念 反射: Refelection,反射是Java的特征之一,允许运行中的Java程序获取自身信息,并可以操作类或者对象的内部属性 通过反射,可以在运行时获得程序或者程序中的每一个类型的成员活 ...

  8. 如何基于 String 实现同步锁?

    如何基于String实现同步锁? 在某些时候,我们可能想基于字符串做一些事情,比如:针对同一用户的并发同步操作,使用锁字符串的方式实现比较合理. 因为只有在相同字符串的情况下,并发操作才是不被允许的. ...

  9. Redis压测

    测试命令 ​ 这条命令redis自带 redis-benchmark [option] [option value] redis 性能测试工具可选参数如下所示: 序号 选项 描述 默认值 1 -h 指 ...

  10. 记Aspose.Word的使用中出现的问题

    最近实现一个功能,具体需求就是把数据库中的内容转换成word文档,文档中需要包含标题.目录以及表格信息. 这里我使用的是Aspose.Word类,这是一个很强大的文档操作工具包,实现了所有操作文档的所 ...