【 tulaoshi.com - Web开发 】
                             
                            扩展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值进行操作。