jQueryjquery form validatee 设置某一个文本框中的某一条规则键盘按下弹起(onkeyup)不触发验证

当前位置:&&
本页文章导读:
&&&&?jquery的键盘事件修改代码&&&&&&
代码如下:(function($){ var no_ie_pr=function(e){ var _this=e; var tabpr=function(e){ _this.attr('tabIndex', 1).click(function(){ _this.focus(); }); if(!$.browser.msie){ _this.css("outline-style", "none"); } } var gettag=_this[0].tagName.toLowerC......&&&&?从零开始学习jQuery (十一) 实战表单验证与自动完成提示插件&&&&&&
本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,
即使你会使用jQuery也能在阅读中发现些许秘籍.
本文是介绍两个最常用的jQuery插件. 分别用于表......&&&&?从零开始学习jQuery (十) jQueryUI常用功能实战&&&&&&
本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,
即使你会使用jQuery也能在阅读中发现些许秘籍.
本文是实战篇. 使用jQueryUI完成制作网站的大部......
&&&&&&最新IT科技资讯推荐:
[1]jquery的键盘事件修改代码
&&&&来源:&互联网& 发布时间:&
代码如下:(function($){ var no_ie_pr=function(e){ var _this=e; var tabpr=function(e){ _this.attr('tabIndex', 1).click(function(){ _this.focus(); }); if(!$.browser.msie){ _this.css("outline-style", "none"); } } var gettag=_this[0].tagName.toLowerCase(); var oe=['abbr','acronym','address','b','bdo','big','blockquote','center','cite','dd','del','dir','dfn','dl','dt','em','font','form','h1','h2','h3','h4','h5','h6','i','ins','img','ins','kbd','li','menu','ol','p','pre','q','s','samp','small','strike','strong','sub','sup','th','tr','tt','u','ul','var']; if($.inArray(gettag,oe)!=-1){ tabpr(); }else{ if ($.browser.msie) { var ce=['span','div']; if($.inArray(gettag,ce)!=-1){ //IE只对绝对定位元素和固定定位元素有效,加tabIndex无法消除虚线 }else{ var ce=['label','legend','tbody','tfoot','thead']; if($.inArray(gettag,ce)!=-1){ tabpr(); } } }else{ var ce=['caption','fieldset','table','td','code','div','span','label','legend','tbody','tfoot','thead']; if($.inArray(gettag,ce)!=-1){ tabpr(); } } } } $.fn.oldKeyup=$.fn. $.fn.keyup=function(fn){ no_ie_pr(this); $(this).oldKeyup(fn); } $.fn.oldKeypress=$.fn. $.fn.keypress=function(fn){ no_ie_pr(this); $(this).oldKeypress(fn); } $.fn.oldKeydown=$.fn. $.fn.keydown=function(fn){ no_ie_pr(this); $(this).oldKeydown(fn); } })(jQuery)
[2]从零开始学习jQuery (十一) 实战表单验证与自动完成提示插件
&&&&来源:&互联网& 发布时间:&
本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,
即使你会使用jQuery也能在阅读中发现些许秘籍.
本文是介绍两个最常用的jQuery插件. 分别用于表单验证和自动完成提示(类似google suggest).
研究别人的作品真是一件花时间而且痛苦的过程. 当然也和本人英文不好有关. 总觉得控件作者写了很多文档但是都不够系统, 需要深入研究很多的实例后才能了解作者的思路.所以学习和研究一个插件需要很高成本, 如果发现了Bug并修复需要的成本也是未知数(本次我花了较少的时间解决了自动完成提示插件的一个中文bug, 但是如果复杂的bug就不会这么简单了.).
对于简单应用我首先推荐上文中的jQuery UI. 但是jQuery UI解决的问题有限. 使用jQuery插件是我们最后的一个好办法---还算是好办法, 起码比自己开发要好吧?
很多jQuery的插件编码异常优美, 看一看艺龙首页现在的城市输入框控件, 除了需要为输入框手工添加很多很多属性(onkeyup, onkeydown等等), 而且还不够通用, 占用服务器资源和网络资源.但是当初也是花费了很久的时间完成的作品.
站在巨人的肩膀上, 让我感觉写脚本和写设计C#程序一样, 都有高度和深度可以挖掘. 除了使用作者开发好的功能, 还可以学习如何开发和封装javascript控件. 看过优秀的jQuery插件作者的代码和设计思想后, 常常自叹设计水平差距居然如此之大, 增加自认为脚本高手, 比较过后就是C#程序员和架构师之间的差距.
希望大家通过本章节介绍的两个插件, 除了学会如何使用,
还能够略微领悟到如何封装和设计javascript控件.
三.表单验证插件 validate
在提交表单前常要对用户输入进行校验.ASP.NET的验证控件就是用于此目的, 可以同时进行客户端和服务器端验证. 但是验证控件并没有被所有项目采用. 而且在MVC项目中经常使用自己的客户端验证框架.
在比较了若干表单验证插件后, 决定采用validate插件. 因为其使用简单并且灵活.
http://bassistance.de/jquery-plugins/jquery-plugin-validation/
/Plugins/Validation
/Plugins/Validation/validate#options
1.应用实例
实例代码:&%@ Page Language="C#" %&
&!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&
&html xmlns="http://www.w3.org/1999/xhtml"&
&head id="Head1" runat="server"&
&title&jQuery PlugIn - 表单验证插件实例 Validate &/title&
&!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader--&
&link rel="stylesheet" type="text/css" href="&%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%&" /&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/jquery-min-lastest.js"&&/script&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"&&/script&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/plugin/jquery.validate/jquery.validate.min.js"&&/script&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/plugin/jquery.validate/localization/messages_cn.js"&&/script&
&% if (false)
{%&&script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"&&/script&
&script type="text/javascript"&
/*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/
&style type="text/css"&
font-size:12
/* form中显示文字的label */
display: -moz-inline-
line-height: 1.8;
display: inline-
text-align:
/* 出错样式 */
input.error, textarea.error
border: solid 1px #CD0A0A;
label.error
color:#CD0A0A;
margin-left:5
/* 深红色文字 */
color:#CD0A0A;
&form id="commentForm" method="get" action=""&
&fieldset &&legend&表单验证&/legend&
&p&&label for="cname" &&em &*&/em& 姓名:&/label&
&input id="cname" name="name" size="25"
minlength="2" /&
&p&&label for="cemail" &&em &*&/em& E-Mail:&/label&
&input id="cemail" name="email" size="25"/&
&p&&label for="curl" &网址:&/label&
&input id="curl" name="url" size="25"
value="" /&
&p&&label for="ccomment" &&em &*&/em& 内容:&/label&
&textarea rows="2" id="ccomment" name="comment" cols="20"
&&/textarea&
type="submit" value="提交" /&
&/fieldset&
&script type="text/javascript"&
/*==========用户自定义方法==========*/
/*==========事件绑定==========*/
$(function()
/*==========加载时执行的语句==========*/
$(function()
$("#commentForm").validate(
errorClass: "error",
submitHandler: function(form)
//如果想提交表单, 需要使用form.submit()而不要使用$(form).submit()
alert("submitted!");
//为name为email的控件添加两个验证方法:required()和email()
email: { required: true, email: true }
messages: {
//为name为email的控件的required()和email()验证方法设置验证失败的消息内容
email: {required:"需要输入电子邮箱", email:"电子邮箱格式不正确"}
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
2. 实例讲解
(1) 验证方法
验证方法是验证某一个控件是否满足某些规则的方法, 返回一个boolean值. 比如email( ) 方法验证内容是否符合email格式, 符合则返回true. 下面是类库中email方法的源代码:
// /Plugins/Validation/Methods/email
email: function(value, element) {
// contributed by Scott Gonzalez: /email_address_validation/
return this.optional(element) || /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i.test(value);
/Plugins/Validation
中的 List of built-in Validation methods 一节中列出了所有内置的验证方法. 同时插件还提供了additional-methods.js 文件, 里面包含了更多的验证方法, 引入后既可启用.
(2) 验证消息
验证消息就是验证方法失败后显示的文字内容. 验证消息一定关联在某一个验证方法上, 并且全局的验证消息保存在jQuery.validator.messages 属性中.
默认的validate类库自带英文验证消息:
messages: {
required: "This field is required.",
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
上面说明当required验证方法验证失败是, 显示"This field is required."这条消息.
在下载文件的localization文件夹中, 包含了各国语言的基本验证消息, 如同本实例一样引入不同的语言文件即可实现语言切换:&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/plugin/jquery.validate/localization/messages_cn.js"&&/script&
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
语言文件的内容举例:jQuery.extend(jQuery.validator.messages, {
required: "必选字段",
});.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
现在必填项的问题提示就变成了中文.
除了全局默认的验证消息, 也可以为某一个表单元素设置特有的验证消息, 比如本文实例中, 为email元素设置了特有的验证消息:
messages: {
//为name为email的控件的required()和email()验证方法设置验证失败的消息内容
email: {required:"需要输入电子邮箱", email:"电子邮箱格式不正确"}
options的messages属性可以针对某一个表单元素设置验证消息, 第一个email表示email元素, 值是一个集合, required就表示required验证函数, 第二个email表示是email验证函数.
(3)验证规则
验证规则就是这样的语意语句: 在元素A上, 使用 验证方法A 和 验证方法B 进行验证.
验证规则将元素与验证方法关联起来, 因为验证方法同时也关联了验证消息, 所以元素与消息也关联了起来.
为一个元素添加验证规则有多种方式.
本实例的"姓名"元素使用了CSS样式规则和元素属性规则:&input id="cname" name="name" size="25"
minlength="2" /&
class元素属性设置元素的CSS样式类, 因为样式类中添加了required类,
所以会和required()验证函数关联. 这种规则叫做CSS样式规则.
minlength元素属性也会自动和minlength()验证函数关联, 这种规则叫做元素属性规则.
另外还可以通过编程的方式进行关联:
//为name为email的控件添加两个验证方法:required()和email()
email: { required: true, email: true }
上面的语句表名为email表单对象添加了required()和email()验证函数.
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
默认情况下, 当验证函数失败时表单不会提交.
但是可以通过添加的方式让提交按钮跳过验证:&input type="submit"
name="cancel" value="Cancel" /&
当表单提交时, 会触发options中submitHandler属性设置的函数:
submitHandler: function(form)
//如果想提交表单, 需要使用form.submit()而不要使用$(form).submit()
alert("submitted!");
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
此函数的签名同上.
我们可以在这个函数中,
编写在表单提交前需要处理的业务逻辑.
需要注意当最后以编程的方式提交表单时, 一定不要使用jQuery对象的submit()方法, 因为此方法会触发表单验证,并且再次调用submitHandler设置的函数, 会导致递归调用.
此函数的参数form就是表单对象, 用途就是不进行验证提交表单:form.submit()
(5) DEBUG模式
在开发阶段我们通常不希望表单被真正提交,
虽然可以通过本实例中重写submitHandler函数来实现, 但是还有更好的方式, 我们可以在submitHandler函数完成正式提交的逻辑, 然后通过设置options的debug属性, 来达到即使验证通过也不会提交表单的目的:$(".selector").validate({
debug: true
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
(6) 多表单验证
有时会在一个页面上出现多个Form, 因为validate控件是针对form对象进行包装的, 所以我们可以控制哪些form对象需要验证.
同时为了方便一次设置页面上所有的应用了validate控件的form对象,
提供了 jQuery.validator.setDefaults 函数让我们可以一次设置所有的默认值:jQuery.validator.setDefaults({
debug: true
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
四.自动完成插件 autocomplete
autocomplete插件能帮助我们实现类似于Google Suggest的效果:
http://bassistance.de/jquery-plugins/jquery-plugin-autocomplete/
/Plugins/Autocomplete
/Plugins/Autocomplete/autocomplete#toptions
1.应用实例
本实例演示的是使用autocomplete完成对输入城市的自动提示效果,如图:
实例代码:&%@ Page Language="C#" %&
&!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&
&html xmlns="http://www.w3.org/1999/xhtml"&
&head id="Head1" runat="server"&
&title&jQuery PlugIn - 自动完成插件实例 AutoComplete &/title&
&!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader--&
&link rel="stylesheet" type="text/css" href="&%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%&" /&
&link rel="stylesheet" type="text/css" href="&%=WebConfig.ResourceServer +"/JsLib/jquery/plugin/jquery.autocomplete/jquery.autocomplete.css"%&" /&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/jquery-min-lastest.js"&&/script&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"&&/script&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/plugin/jquery.autocomplete/jquery.autocomplete.min.js"&&/script&
&% if (false)
{%&&script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"&&/script&
&script type="text/javascript"&
/*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/
&style type="text/css"&
font-size: 12
.formLabel{float: width: 150 text-align:}
.formInput{float:}
&!-- Demo. 应用AutoComplete插件 --&
Demo. 应用AutoComplete插件 &/h3&
&label for="inputCityName"&请输入城市拼音和汉字:&/label&
&input id="inputCityName" name="inputCityName" type="text" /&
&label for="inputCityName"&城市ID:&/label&&/div&
&input id="inputCityId" name="inputCityId" type="text" /&&/div&
&script type="text/javascript"&
/*==========用户自定义方法==========*/
//城市数据
//autocomplete选项
var options = {
minChars: 1,
width: 250,
matchContains: true,
formatItem: function(row, i, max)
return i + "/" + max + ": \"" + row.CityNameEn + "\" [" + row.CityName + "]";
formatMatch: function(row, i, max)
return row.CityNameEn + " " + row.CityN
formatResult: function(row)
return row.CityN
//autocomplete初始化函数
function initAutoComplete(data)
cityList =
$("#inputCityName").autocomplete(cityList, options);
$("#inputCityName").result(function(event, data, formatted)
$("#inputCityId").val(data.ElongCityId);
/*==========事件绑定==========*/
$(function()
/*==========加载时执行的语句==========*/
$(function()
//加载城市数据, 并在回调函数中用返回的数据初始化autocomplete
$.getJSON("cityinfo.htm", null, initAutoComplete)
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
2. 实例讲解
(1)准备数据源
首先要准备实现自动建议的数据源. 本实例是通过发送Ajax请求获取JSON对象. autocomplete()方法支持两个参数, 第一个是data, 第二个是options.
其中data参数可以使本实例中的一个数据变量, 也可以是一个url. 如果是url则会每次都调用Ajax请求获取数据.
为了效率我倾向于在数据量允许的情况下, 在页面加载后使用Ajax获取全部的数据, 然后使用传递数据变量给autocomplete组件. 如实例中所示. 除非数据特别巨大无法再客户端加载,
则只能每次都使用发送Ajax请求从服务器端获取部分数据. 但是这会对服务器造成负担.
(2) 设置关键函数
虽然options是可选项, 但是对于我们的数据源cityList是一个多属性对象, 所以必须设置下面几个关键的配置项后才能够使用:
formatItem
对匹配的每一行数据使用此函数格式化, 返回值是显示给用户的数据内容.
function(row, rowNum, rowCount, searchItem)
row: 当前行. the results row,
rowNum: 当前行号,从1开始.(注意不是索引,索引从0开始) the position of the row in the list of results (starting at 1),
rowCount: 总的行号 the number of items in the list of results
searchItem: 查询使用的数据, 即formatMatch函数返回的数据格式的内容. 我们在formatMatch函数中会设置程序内部搜索时使用的数据格式,这个格式和给用户展示的数据是不同的.
formatMatch
对每一行数据使用此函数格式化需要查询的数据格式. 返回值是给内部搜索算法使用的. 实例中用户看到的匹配结果是formatItem中设置的格式, 但是程序内部其实只搜索城市的英文和中文名称, 搜索数据在formatMatch中定义:return row.CityNameEn + " " + row.CityN
function(row, rowNum, rowCount,)
参数说明同上
formatResult
此函数是用户选中后返回的数据格式. 比如实例中只返回城市名给input控件:return row.CityN
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
function(row, rowNum, rowCount,)
参数说明同上
(3) 为控件添加Result事件函数
上面3个函数无法实现这类要求: 虽然只返回城市名称, 但是查询时使用城市ID, 选中一个城市后需要将城市ID存储在一个隐藏域中.
所以autocomplete控件提供了result事件函数, 此事件会在用户选中某一项后触发:
$("#inputCityName").result(function(event, data, formatted)
$("#inputCityId").val(data.ElongCityId);
function(event, data, formatted)
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
Result事件会为绑定的事件处理函数传递三个参数:
event: 事件对象. event.type为result.
data: 选中的数据行.
formatted:
虽然官方的解释应该是formatResult函数返回的值, 但是实验结果是formatMatch返回的值. 在本实例为: "Beijing
(4) 匹配中文
当前版本的autocomplete控件对中文搜索存在Bug, 原因是其搜索事件绑定在keydown事件上, 当使用中文输入法输入"北"字时没有任何提示. 我对原库做了修改, 将keydown事件修改为keyup事件, 即可完成对中文的智能提示搜索. 另外主要需要将"matchContains"配置项设置为"true", 因为我们的搜索格式是"Beijing 北京", 默认只匹配开头的字符.
(5) 更多配置项
关于更多的配置项, 请参考官方文档:
/Plugins/Autocomplete/autocomplete#toptions
(6) 更多事件
除了上面介绍的autocomplete()和result()函数, 还有如下函数:
search( ) : 激活search事件
flushCache( ) : 清空缓存
setOptions( options ) : 设置配置项
本文详细介绍了表单验证插件和自动完成插件, 目前大家可以搜索到很多的插件应用, 或者上千的插件列表, 但是却找不到详细的使用文档. 插件用起来简单但是真正的灵活应用却不容易, 除了要翻越英文文档学习基本的使用, 还要花很长时间了解各个参数的作用, 如何配合使用等. 并且在上面做二次开发的难度相对较大, 插件的核心代码多没有注释并且复杂,
要在其中寻找逻辑关系要花费很多时间和精力. 本文介绍的两个插件更多的细节请参考官方文档, 地址都在一开始为大家提供了.
后续文章我决定先进行jQuery技巧和javascript必备知识的讲解,
我们很少开发自定义插件所以将开发插件篇放在最后.
本章节代码下载:http://xiazai./201101/yuanma/Code-jQueryStudy-11.rar
[3]从零开始学习jQuery (十) jQueryUI常用功能实战
&&&&来源:&互联网& 发布时间:&
本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,
即使你会使用jQuery也能在阅读中发现些许秘籍.
本文是实战篇. 使用jQueryUI完成制作网站的大部分常用功能.
经过公司内部收集, 整理了一些经常使用javascript实现的功能.
实现这些功能的主角不是让人眼花缭乱的jQuery插件,
而是jQuery UI.
如果你还在为了一个小小的特效而去下载并安装插件, 发现Bug还没有人替你解决. 记住插件是我们没有办法的最后选择.
使用插件有太多的坏处:
1.不利于维护
2.增加页面大小
3.不利于成员间交流共享,具有学习成本.
4.不够健壮, 不能保证插件版本一直更新并修复所有问题.
下面就引入今天的主角:jQuery UI
三.jQuery UI
jQuery UI 是 jQuery 的一部分, 是在jQuery之上的一套专门用于UI交互的类库.
使用jQuery UI可以实现底层交互, 各种高级特效, 动画, 并且可定制主题.
我们可以用它轻松的构建高度交互的Web应用程序.
官方首页: http://jqueryui.org/
下载: /download
示例和文档: /demos/
皮肤: /themeroller/
jQuery UI 的在线网站十分强大. 首先就是在下载时可以组装自己想要的功能定制下载:
并且针对各种控件不仅提供了详细的参数说明和实例,
还可以随时更换实例的皮肤:
本文主要讲解实例, 大家可以通过实例代码快速上手jQuery UI.
使用jQuery UI我们可以再不借助其他插件的情况下完成大部分页面应用, 说其是一个官方的超级UI插件也不为过. 包含所有功能的jQuery UI类库文件为188K, 启用Gzip压缩后是45K. 虽然较大但是一次加载全网站获益.而且45K大小在当今的互谅网时代还算可以接受.
目前还没有jQuery UI的中文教程.
因为本文是实战篇, 所以不会仔细讲解基础内容. 在后面的章节中我会加入jQuery UI的基础教程.争取成为中文jQuery UI第一教程.
四. 准备工作
我将所有相关的文件, 包括各种类库文件, Theme模板放置在如下路径:
此路径开通了目录浏览, 可以直接查找需要的文件. 目录组织结构按照本系列: (八) 插播:jQuery实施方案 中介绍的方案组织.
另外也可以从Google上引用文件, Google的CDN速度更快也更有保证, 参见: Google's CDN
本文的实例的所有引用都使用 WebConfig.ResourceServer 这个属性:public class WebConfig
public static string ResourceServer = @"/";}
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
五.弹出层对话框
弹出框是最常用最实用的功能.
先来看一下艺龙网上的一些应用场景.
1. 艺龙网应用场景举例
(1) 静态提示类弹出层. 弹出层的内容是固定的.
(2) 动态提示类弹出层. 弹出层内容是根据事件源变化的.
(3)遮罩类弹出层. 弹出时背景变灰并不可点击.
2. 应用实例
使用 jQuery UI 的 Dialog 组件. 我以轻松实现上面三种效果.
Dialog组件的主要特点是可以拖动(Draggable), 可以改变大小(Resizable) .
示例完整代码如下:&%@ Page Language="C#" %&
&!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&
&html xmlns="http://www.w3.org/1999/xhtml"&
&head id="Head1" runat="server"&
&title&jQuery UI - 弹出层应用实例 Dialog&/title&
&!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader--&
&link rel="stylesheet" type="text/css" href="&%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%&" /&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/jquery-min-lastest.js"&&/script&
&script src="&% =WebConfig.ResourceServer %&/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"
type="text/javascript"&&/script&
&% if (false)
{%&&script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"&&/script&
&script type="text/javascript"&
/*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/
&style type="text/css"&
&!-- Demo 静态提示类弹出层 --&
&h3&Demo. 共享同一个静态弹出层, 弹出层内容固定: &/h3&
&span id="spanShowTip1"&显示提示&/span&
&span id="spanShowTip2"&显示提示&/span&
&span id="spanShowTip3"&显示提示&/span&
&span id="spanShowTip4"&显示提示&/span&
&!-- Demo 动态提示类弹出层 --&
&h3&Demo. 每个弹出层内容不同, 弹出层内容存储在事件源的元素属性中: &/h3&
&span id="spanShowDataTip1" data="颜色是红色"&红色&/span&
&span id="spanShowDataTip2" data="颜色是绿色"&绿色&/span&
&!-- Demo 遮罩类弹出层 --&
&h3&Demo. 弹出IFrame &/h3&
&input type="button" id="btnShowIframe" name="btnShowIframe" value="显示弹出层"/&
&!-- 提示类弹出层 --&
&div id="divTip" title="自定义标题"&
&p&弹出层&/p&
&!-- 遮罩类弹出层 --&
&div id="divIframe" title="iFrame弹出层" &
&iframe src="" width="450px" height="230px"&&/iframe&
&script type="text/javascript"&
/*==========用户自定义方法==========*/
/*==========事件绑定==========*/
$(function()
//静态提示类弹出层
$("span[id^=spanShowTip]").css("cursor", "pointer").click(function(event)
$("*").stop();
event.stopPropagation();
var top = $(event.target).offset().top + 20;
var left = $(event.target).offset().
$("#divTip").dialog("option", "position", [left, top]);
$("#divTip").dialog("open");
//动态提出类弹出层
$("span[id^=spanShowDataTip]").css("cursor", "pointer").click(function(event)
$("*").stop();
$("#divTip").dialog("close");
event.stopPropagation();
var top = $(event.target).offset().top + 20;
var left = $(event.target).offset().
$("#divTip").html($(event.target).attr("data"));
$("#divTip").dialog("option", "position", [left, top]);
$("#divTip").dialog("open");
//遮罩类弹出层
$("#btnShowIframe").click(function(event)
event.preventDefault();
event.stopPropagation();
$("#divIframe").dialog("open");
//单击自身取消冒泡
$("#divTip, #divIframe").bind("click", function(event)
event.stopPropagation();
//document对象单击隐藏所有弹出层
$(document).bind("click", function(event)
$("#divTip").dialog("close");
$("#divIframe").dialog("close");
/*==========加载时执行的语句==========*/
$(function()
//初始化提示类弹出层
$("#divTip").dialog({
show: null,
bgiframe: false,
autoOpen: false
//初始化遮罩类弹出层
$("#divIframe").dialog({
show: null,
bgiframe: false,
autoOpen: false,
width: 500,
height: 300,
draggable: true,
resizable: false,
modal: true
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
静态提示类弹出层
动态提示类弹出层:
遮罩类弹出层:
3.关键点讲解
(1)计算弹出层位置
提示类弹出框最重要的是计算弹出框的位置. 通过事件对象获取到事件源, 使用offset()函数计算事件源相对于document的位置:
var top = $(event.target).offset().
var left = $(event.target).offset().
因为是相对于document, 即页面左上角的位置, 所以需要将弹出层放在Body元素中的第一层. 即父类就是body. 如果包含在其他元素中, 需要确定任何一个父类的position样式设置为了relative.
计算出来的top和left是事件源的位置, 在此位置显示会将事件源对象遮盖住. 所以通常需要手工做一些偏移, 比如top+20.
(2) 取消冒泡和浏览器默认行为
如果我们为document对象绑定了单击后关闭弹出层的事件, 那么就一定要取消事件的冒泡. 使用event对象的stopPropagation()方法可以取消冒泡.event.stopPropagation();
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
对于具有默认行为的元素,比如提交按钮的提交表单行为, &a&元素的超链接行为等, 我们如果在这些元素上应用事件, 还需要取消它们的默认行为:event.preventDefault();
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
(3) 设置动画效果与取消动画
通过设置dialog的配置项的show属性, 可以设置显示dialog时候的动画效果:$('.selector').dialog({ show: 'slide' });
show默认为null即无动画,
可以是使用下列值:'blind', 'clip', 'drop', 'explode', 'fold', 'puff', 'slide', 'scale', 'size', 'pulsate'.
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
对于这些动画的效果, 可以在此页观看:
/demos/show/
当一个动画效果执行时, 如果用户在此对这个元素进行操作, 就会出现各种问题, 比如定位不准确等. 所以如果应用了动画, 我们在对其操作时需要使用stop()函数来停止动画, 通常是停止虽有元素的动画:$("*").stop();
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
但是即使停止了动画再进行操作, 如果操作的太快也容易产生问题. 所以至于是否使用动画需要经过权衡决定.
(4) 动态提示类弹出层的数据传递
动态提示类弹出层的数据是不同的,
本文实例使用的是将数据存储在元素属性data上:&span id="spanShowDataTip1" data="颜色是红色"&红色&/span&
这是一种简单直观的方式. 比较容易编程实现(尤其是在使用MVC编程模型的时候.)
还有一种常用方式是使用javascript变量存储数据.这两种方式在第5章时有过讲解:
/zhangziqiu/archive//jQuery-Learn-5.html
(5)更换主题
大家注意实例中的弹出层没有为其编辑任何样式, 但是显示出来后已经被美化过了. 这是因为我引用了jQuery UI的主题:
&!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader--&
&link rel="stylesheet" type="text/css" href="&%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%&" /&
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
注释中有很多的主题, 只需要将引用路径中的"redmond"改为其中任何一个, 弹出层的样式会立刻发生变化.
VS中有一个Bug, 就是针对link标签, href中的语句块编译有问题, 某些情况下&%%&不被编辑解析. 所以我使用上面代码中的方式构造href属性值.
可以在下面的地址查看各个主题的效果:
/themeroller/#themeGallery
六.Tab标签
不刷新页面, 在页面中的不同标签间切换:
本实例通过jQuery UI的Tabs组件实现. Tabs组件的使用与dialog一样十分简单,
默认的配置即可实现最简单的tab, 通过设置更多的options可以实现更复杂的应用.
1.应用实例
源代码:&%@ Page Language="C#" %&
&!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&
&html xmlns="http://www.w3.org/1999/xhtml"&
&head id="Head1" runat="server"&
&title&jQuery UI - 弹出层应用实例 Dialog&/title&
&!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader--&
&link rel="stylesheet" type="text/css" href="&%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%&" /&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/jquery-min-lastest.js"&&/script&
&script src="&% =WebConfig.ResourceServer %&/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"
type="text/javascript"&&/script&
&% if (false)
{%&&script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"&&/script&
&script type="text/javascript"&
/*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/
&style type="text/css"&
&!--Demo.默认Tab与Ajax Tab --&
&div id="tabs1" &
&li&&a href="#tabs1-1"&One&/a&&/li&
&!-- Ajax Tab --&
&li&&a href="TabData.htm"&Two&/a&&/li&
&li&&a href="#tabs1-3"&Three&/a&&/li&
&div id="tabs1-1"&
&p&Tab1内容&/p&
&div id="tabs1-3"&
&p&Tab3内容&/p&
&!--Demo. 可折叠的Tab --&
&div id="tabs2" &
&li&&a href="#tabs2-1"&One&/a&&/li&
&li&&a href="#tabs2-2"&Two&/a&&/li&
&li&&a href="#tabs2-3"&Three&/a&&/li&
&div id="tabs2-1"&
&p&Tab1内容&/p&
&div id="tabs2-2"&
&p&Tab2内容&/p&
&div id="tabs2-3"&
&p&Tab3内容&/p&
&!--Demo. 鼠标滑动即切换的Tab --&
&div id="tabs3" &
&li&&a href="#tabs3-1"&One&/a&&/li&
&li&&a href="#tabs3-2"&Two&/a&&/li&
&li&&a href="#tabs3-3"&Three&/a&&/li&
&div id="tabs3-1"&
&p&Tab1内容&/p&
&div id="tabs3-2"&
&p&Tab2内容&/p&
&div id="tabs3-3"&
&p&Tab3内容&/p&
&script type="text/javascript"&
/*==========用户自定义方法==========*/
/*==========事件绑定==========*/
$(function()
/*==========加载时执行的语句==========*/
$(function()
//默认Tabs
$("#tabs1").tabs();
//可折叠的Tabs
$("#tabs2").tabs({
collapsible: true
//鼠标滑动即切换的Tabs
$("#tabs3").tabs({
event: "mouseover"
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
1. 默认设置的Tabs, Two标签内容使用Ajax获取
2.再折叠tab
3.鼠标滑动即切换的tab
2.要点讲解
(1) 注意Tabs中的HTML结构.
使用ul构建标签. 内容div一定要和标签关联, 没有关联的div将不被处理直接显示.
(2) 使用Ajax可以不指定内容容器, 但是也可以将Ajax内容放入指定容器中.&li&&a href="hello/world.html" title="Todo Overview"& ... &/a&&/li&
&div id="Todo_Overview"& ... &/div&
tab有很多事件:
select, load, show, add, remove, enable, disable
使用这些事件可以完成很多复杂任务. 需要注意事件的签名:$('#example').bind('tabsselect', function(event, ui) {
// Objects available in the function context:
// anchor element of the selected (clicked) tab
// element, that contains the selected/clicked tab contents
// zero-based index of the selected (clicked) tab
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
第一个是事件对象, 第二个ui对象是传递的额外参数, 我们可以获取tab对象, tab所在容器和tab的索引值.
比如我们可以在事件中做验证:$('#example').tabs({
select: function(event, ui) {
var isValid = ... // form validation returning true or false
return isV
或者当添加一个tab时立刻切换到选中状态:var $tabs = $('#example').tabs({
add: function(event, ui) {
$tabs.tabs('select', '#' + ui.panel.id);
});.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
活学活用, 更多应用大家也可以参见tab组件的官方文档:
/demos/tabs
七. 手风琴菜单
使用jQuery UI的accordion组件可以实现手风琴菜单. 效果见下图.
accordion文档地址: /demos/accordion/
1.实例效果
2.实例代码&%@ Page Language="C#" %&
&!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&
&html xmlns="http://www.w3.org/1999/xhtml"&
&head id="Head1" runat="server"&
&title&jQuery UI - 手风琴菜单应用实例 Accordion &/title&
&!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader--&
&link rel="stylesheet" type="text/css" href="&%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%&" /&
&script type="text/javascript" src="&% =WebConfig.ResourceServer %&/JsLib/jquery/jquery-min-lastest.js"&&/script&
&script src="&% =WebConfig.ResourceServer %&/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"
type="text/javascript"&&/script&
&% if (false)
{%&&script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"&&/script&
&script type="text/javascript"&
/*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/
&style type="text/css"&
font-size: 12
&!-- Demo. 默认配置的Accordion菜单 --&
&div id="accordion1"&
&h3&&a href="#"&菜单1&/a&&/h3&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
&h3&&a href="#"&菜单2&/a&&/h3&
菜单2的内容
&h3&&a href="#"&菜单3&/a&&/h3&
菜单3的内容
&!-- Demo. 取消自动高度, 可折叠 --&
&div id="accordion2"&
&h3&&a href="#"&菜单1&/a&&/h3&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
&h3&&a href="#"&菜单2&/a&&/h3&
菜单2的内容
&h3&&a href="#"&菜单3&/a&&/h3&
菜单3的内容
&!-- Demo. 鼠标滑动触发, 自定义图标 --&
&div id="accordion3"&
&h3&&a href="#"&菜单1&/a&&/h3&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
菜单1的内容&br /&
&h3&&a href="#"&菜单2&/a&&/h3&
菜单2的内容
&h3&&a href="#"&菜单3&/a&&/h3&
菜单3的内容
&script type="text/javascript"&
/*==========用户自定义方法==========*/
/*==========事件绑定==========*/
$(function()
/*==========加载时执行的语句==========*/
$(function()
//默认配置的Accordion菜单
$("#accordion1").accordion();
//取消自动高度, 可折叠
$("#accordion2").accordion({
autoHeight:false,
collapsible: true
//鼠标滑动触发, 自定义图标
$("#accordion3").accordion({
header: "ui-icon-circle-arrow-e",
headerSelected: "ui-icon-circle-arrow-s"
event: "mouseover"
.csharpcode, .csharpcode pre
font-size:
font-family: consolas, "Courier New", courier,
background-color: #
/*white-space:*/
.csharpcode pre { margin: 0 }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000 }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
background-color: #f4f4f4;
width: 100%;
.csharpcode .lnum { color: #606060; }
3. 关键点讲解
(1) 注意高度设置过小问题
当包含accordion控件的容器高度设计过小时, 在FireFox3中在此容器后面的内容会被accordion控件部分遮盖. 在IE中没有此问题. 经检查是因为容器高度小于菜单高度导致.
所以我们在应用时应当注意不要将容器高度设置过小.
(2) 部分关键属性
autoHeight: 设置是否自动将内容高度设置为容器高度.
collapsible: 设置是否可折叠
一般上面两个配合使用,
以为折叠后肯定会改变菜单高度, 会导致autoHeight设置为true无效.
更多属性和事件使用请参阅官方文档.
本章简单介绍了jQueryUI, 并且使用jQuery UI完成了弹出层,tabs,手风琴菜单的应用实例. 使用jQuery UI可以不需要额外寻找插件. 并且实现简单.
但是有些功能是必须使用插件完成的. 下一张讲解两个插件实例: 自动完成插件AutoComplete 和 表单验证插件jQuery Validate.
本章源代码下载: http://xiazai./201101/yuanma/Code-jQueryStudy-10.rar
最新技术文章:
特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!
(C)2012-,站长邮箱:www_169it_(请将#改为@)}

我要回帖

更多关于 jquery onkeyup 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信