您的位置:首页 > Web前端 > JQuery

jQuery-插件,优化

2016-02-10 15:59 591 查看
jQuery应用:

1、表单验证:

A:jQuery Validation插件:有时需要将验证的属性写在class中,有时需要将验证信息写在属性中,例如:

<input id="cemail" name="email" size="25" class="require email" minlength=“2”/>

$(document).ready(function(){

$("#commentForm").validate()

})

B:jQuery.metadata.js插件:可以将所有的验证信息都写在class属性中

$('#commentForm').validate({meta:"validate"});

<inout id="cusername" name="username" size="25" class="{validate:{required:true,minlength:2}}"

C:将class属性移除,利用name属性;

$(document).ready(function(){

$("#commentForm").validate({

rules:{

username:{

required:true,

minlength:2

},

email:{

required:true,

email:true

},

url:"url",

comment:"required"

}

});

})

D:自定义验证信息:

class="{validate:{required:true,message:{required:'请输入姓名',minlength"'请至少输入2个字符'}}}"

E:验证码:

<input id="cvalcode" name="valcode" size="25" value="" />

$.validator.addMethod(

"formula",

function(value,element,param){

return value == eval(param);

}

'请输入数学公式计算后的结果'

)

在$("#commentForm").validate的rules中添加valcode:{formula:“7+9”}

2、jQueryForm插件:ajaxForm()以及ajaxSubmit()方法

$("#myForm").ajaxForm(function(){

$('#output1').html("提交成功").show();

})

*****************************

$('#myForm').submit(function(){

$(this).ajaxSubmit(function(){

$('#output1').html("提交成功").show();

})

return false;

})

*****************************

两个方法都可以传递一个或0个参数,单个参数可以是一个回调函数,可以是一个options对象:

var options={

target:'#output1',

beforeSubmit : showRequest, //提交前回调函数

success : showRespone, //提交成功后的回调函数

url : url, //默认是form中action的值,如果申明,则会被覆盖

type : type, //get,post

setTimeout : 3000,

clearForm : true, //提交成功后,清除所有表单元素的值

resetForm : true, //提交成功后,重置所有表单元素的值

dataType : null //json ……接收服务端返回的类型

}

$('#myForm').submit(function(){

$(this).ajaxSubmit(options);

return false;

});

beforeSubmit指定的回调函数:

function showRequest(formData,jqForm,options){

//formData是一个数组对象,jqForm是一个jQuery对象,封装了表单元素

var queryString = $.param(formData);

return true;

}

success指定的回调函数:

function showResponse(responseText,statusText,xhr,$form){

//statusText是一个返回状态,success,error……

//responseText携带服务器返回的数据内容,对于缺省的html返回,第一个参数是XMLResquest对象的responseText

}

在提交前验证表单:利用formData参数,利用参数jqForm,利用fieldValue()方法

3、创建模态窗口---SimpleModal插件

$(“#element-id”).modal()

$.modal(“<div><h1>SimpleModel</h1></div>”)

还可以传一个参数:

$(“#element-id”).modal({options})

$.modal(“<div><h1>SimpleModel</h1></div>”,{options})

<a herf="#" class="simplemodal-close">关闭</a>

"simplemodal-close"是一个默认关闭接口,只要通过调用$.modal.close()方式关闭当前模态窗口

如果想自己定义一个关闭接口,可以修改全局变量:

$.modal.defaults.closeClass = "modalClose";

修改多个默认参数:

$.extend($.modal.defaults,{

closeClass:"modalClose",

closeHtml : "<a herf="#">Close</a>"

})

4、Cookie插件:

A:写入cookie:$.cookie(“the_cookie”, “the_value”);

B:读取cookie:$.cookie(“the_cookie);

C:删除cookie:$.cookie(”the_cookie” , null)

5、jQuery UI插件:拖到排序组件

$(document).ready(function(){

$("#myList").sortable(); //可以拖动

})

//单与单击事件冲突时:

$("#myList").sortable({delay:1});

获取列表元素拖到后的顺序,sortable(“serialize”)

$("#myList").sortable({

delay:1,

stop:function(){

$.post(

"sortable.php",

$("#myList").sortable("serialize"),

function(response){

alert(response);

}

)

}

})

6、编写jQuery插件:

A:

;(function($){

$.fun.extend({

“color”:function(value){},

“border”:function(value){}

})

})(jQuery);

Jquery Mobile:

1、加载顺序:

<link rel="stylesheet" type="text/css" href="jquery.mobile.css">

<script type="text/javascript" src="jquery.js"></script>

………………//这里是项目中的其他js

<script type="text/javascript" src="jquery.mobile.js"></script>

2、在HTML5中,属性名有data-前缀

jQuery性能优化:

1、事件代理时:

$('#myTable').on('click','td',function(){

})

2、使用join()将数组转化为字符串

3、$.proxy()的使用:

<div id="panel" style="display:none">

<button>close</button>

</div>

//执行下面代码,button元素会消失

$('#panel').fadeIn(function(){

$("#panel button").click(function(){

$(this).fadeOut();

});

});

//使用$.proxy()解决上述问题

$('#panel').fadeIn(function(){

$("#panel button").click($.proxy(function(){

//this指向#panel

$(this).fadeOut();

},this));

});
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: