上一张总结了jquery中常见的选择器,原生和jquery相互转换, DOM,事件,运动,没有阅读的同学,请回头查看;
jQuery.Callbacks 事件触发机制
这个函数常见的应用场景是事件触发机制,也就是设计模式中的观察者(发布、订阅机制),我是在QQ音乐项目中带着大家用到此方法,不熟悉的同学回头去看QQ音乐项目我录制的视频;
1、 不传入任何参数,调用add的时候将函数add到内部的list中,调用fire的时候顺序触发list中的回调函数;
function fn1(val){ console.log('fn1 says:' + val);}function fn2(val){ console.log('fn2 says ' + val);}var cbs = $.Callbacks(); //我们通过调用$.Callbacks获取到一个callback实例cbs.add(fn1); //向内部队列添加函数,等同于我讲过的订阅发布中的“事件订阅”//fn1 says:leileicbs.fire('leilei'); //依次执行队列里的函数,等同于订阅发布中的"发布",这里的leilei参数会被fn1和fn2的参数val接收cbs.add(fn2);//fn1 says:ymy//fn2 says ymycbs.fire('ymy');
2、构造函数传入once,回调函数列表只被fire一次
function fn1(val){ console.log('fn1 says ' + val);}var cbs = $.Callbacks('once');cbs.add(fn1);//fn1 says foo cbs.fire('foo');cbs.fire('foo');
3、构造函数传入unique,保证在add过程中没有重复的函数
function fn1(val){ console.log('fn1 says ' + val);}var cbs = $.Callbacks('unique');cbs.add(fn1);cbs.add(fn1);//虽然添加了两次,但因为有unique这个选项,所以只会有一次输出//fn1 says foo cbs.fire('foo');
jquery中前后台数据交互
我最常用 $.ajax,里面参数可以省略掉很多,只留type,url,success;其他参数根据需要而定;
$.ajax({ type: "POST", //请求方式,常用的get,post,jsonp url: "some.php", //请求地址 data: "name=John&location=Boston", //前端传给后台的参数 dataType:'json',//后台返回的数据格式为json格式 cache:false, //是否缓存 async:false, //强制要求同步 success: function(msg){ //请求成功后接收到的数据,数据就是msg alert( "Data Saved: " + msg ); }});
数组和对象操作
1、$.each——遍历$.each(obj,function(param1,param2))遍历数组时:param1为元素序号,param2为元素内容;遍历对象时:param1为元素属性名,param2为元素属性值。注意:该工具方法很强大,支持遍历原生和jquery元素2、$.grep——筛选数组$.grep(array,function(element,index)):array为要筛选的数组,element为数组中的元素,index为元素在数组中的序号(0起)。
var arrNum = [2, 8, 3, 7, 4, 9, 3, 10, 9, 7, 21];var arrGet = $.grep(arrNum, function(ele, index) { return ele > 5 && index < 8 //筛选出:元素值大于5且序号小于8的新数组})//筛选后数据:8,7,9,10
3、$.map——数据变更$.map(array,function(element,index)):array为要筛选的数组,element为数组中的元素,index为元素在数组中的序号;和$.each的区别,就是map有返回值,而each没有返回值4、$.inArray()——查找数组元素$.inArray(value,array):查找元素在数组中的元素,如果不存在则返回-1。
var arrNum = [4, 21, 2, 12, 5];var arrPos = $.inArray(12, arrNum); //结果:3
字符串操作
$.trim():去掉字符串左右两侧的空格。这是jQuery核心库中唯一针对字符串处理的函数。
URL操作
$.param(obj):其中obj为数组或者jquery对象,该方法将其序列化为键值对。
var arrInfo = { id: 101, name: "lei" , sex: 0 }; //基本信息数组var arrNewInfo = $.param(arrInfo);//arrNewInfo; 结果:id=101&name=lei&sex=0
jquery插件的扩充
$.fn.extend() 给原型上扩充插件,只有实例可以使用这些扩充的方法;
$.fn.extend({ "test": function (p1, p2) { return p1 && p2; }})//只有实例可以使用$().test('ymy','leilei'); //返回 true;
$.extend() 给类上扩充插件,实例不能使用,只有类可以使用
$.extend({ "test": function (p1, p2) { return p1 && p2; }})//只有类可以使用$.test('ymy','leilei'); //返回 true;
$.proxy——改变事件函数的作用域
两种格式:$.proxy(function,scope):function为指定的事件方法,scope为事件函数设置作用域的对象。$.proxy(scope,functionName):scope为函数的作用域对象,functionName为函数名,它必须是scope对象的一个属性。
$( function() { var objMyInfo = { name: "小蕾", //设置对象name属性 sex: "女", //设置对象sex属性 ShowEvent: function() { //设置执行的事件 $( "#divShow").html("姓名:" + this.name + "
性别:" + this.sex); }}//结果:姓名:"",性别:undefined$( "#Button1").bind("click" ,objMyInfo.ShowEvent); //通过proxy函数绑定设置的事件。结果:姓名:小蕾,性别:女。$( "#Button1").bind("click" ,$.proxy(objMyInfo, "ShowEvent"));//通过proxy函数绑定设置的事件。结果:姓名:小蕾,性别:女。$( "#Button1").bind("click" , $.proxy(objMyInfo.ShowEvent, objMyInfo));
jQuery获得select option的值和对select option的操作
获取Select :
获取select 选中的 text :$("#ddlRegType").find("option:selected").text();
获取select选中的 value:常用于表单元素值的获取$("#ddlRegType ").val();
获取select选中的索引:$("#ddlRegType ").get(0).selectedIndex;
设置select:
设置select 选中的索引:$("#ddlRegType ").get(0).selectedIndex=index;//index为索引值
设置select 选中的value:
$("#ddlRegType ").attr("value","Normal“); $("#ddlRegType ").val("Normal"); $("#ddlRegType ").get(0).value = value;
清空 Select:
$("#ddlRegType ").empty();