jQuery textarea的长度进行验证 |
扩展textarea 属性,结合jquery.validate.js,在提交表单同时,加上对textarea的长度进行验证 。 1.jQuery 对textarea 长度进行验证的插件 复制代码 代码如下: //对textarea 长度进行验证 jQuery.fn.checkLength = function(parameters) { defaults = { min: 0 , max: 5 } jQuery.extend(defaults, parameters); // 当前textarea 的值 var taValue = $(this).val(); var len = taValue.length; if (len >= defaults.max) { $(this).parent().append(showLengthError("max")).show(); window.setTimeout(function() { $(".lenError").hide(); }, 5000); return false; } else if (len <= defaults.min) { $(this).parent().append(showLengthError("min")); window.setTimeout(function() { $(".lenError").hide(); }, 5000); return false; } else { return true; } //todo: 当键盘输入在正确范围的时候,消除提示 } 注释: 1) 参数传递: defaults = { min: 0 , max: 5 } 分别用于用于接收textarea的最短和最大长度 。 2) 返回值 true : 验证长度通过 false : 验证长度失败 2. 使用说明: 在页面添加js引用: <script type="text/javascript" src="../../../scripts/jquery/jquery.textarea.js"></script> 示例: 在页面中 <textarea id="txtContent" rows="4" cols="40"></textarea> <button id="chklen">Check Textarea Length</button> 当触发按钮事件的时候,我们就可以对textarea 的长度进行判断了 。 复制代码 代码如下: $("#chklen").click(function(){ var bool = $("#txtContent").checkLength({ min : -1 ,max: 10 }); if(bool){ alert(bool); } }); 如果textarea是在form表单当中的,则在表单提交的同时,进行验证,条件满足的时候再进行提交 。 如下示例: 复制代码 代码如下: // 判断 testarea 长度是否超出限制 var ckContent = $("#txtContentIntro").checkLength({ min : -1 //不判断是否为空 ,max: 512 //最大长度512 }); // 表单验证 var b = $("#fcourseware").valid(); // 执行上传操作,上传成功后保存课件信息 if (b && ckContent ) { // todo: submit form } min和max两个参数均可以不传递值,默认最小长度0,最大长度10.如果textarea不为必填项,则min 值赋予 -1. 最后通过返回bool值进行操作 。 |