最近在研究jQuery。把jQuery.extend扩展函数的用法记录下来。
1、扩展jQuery静态方法.
1data:image/s3,"s3://crabby-images/1d701/1d70146ac1f3016d52a6f84f755fc3859e7a8193" alt="" $.extend( { 2data:image/s3,"s3://crabby-images/5556a/5556ab1433d8144367b3ff79ea4464d2af91b058" alt="" test:function() {alert('test函数')} 3 })
用法: $.test()
2、合并多个对象. 为jQuery.extend(css1,css2)为例,css1,css2个有一些属性(法照样会比处理,这里之讲属性). extend函数会把css2有而css2没有的属性加到css1中,如果css2的某个属性与css1的某个属性名称享用,就会用css2的属性去覆盖css1的同名属性。css1就是最后的整和对象。或者也可以用 : var newcss = jquery.extend(css1,css2) newcss就是合并的新对象。 var newcss = jquery.extend({},css1,css2) newcss就是合并的新对象.而且没有破坏css1的结构。
1 //用法: jQuery.extend(obj1,obj2,obj3, ..) 2data:image/s3,"s3://crabby-images/1d701/1d70146ac1f3016d52a6f84f755fc3859e7a8193" alt="" var Css1= {size: "10px",style: "oblique"} 3data:image/s3,"s3://crabby-images/1d701/1d70146ac1f3016d52a6f84f755fc3859e7a8193" alt="" var Css2= {size: "12px",style: "oblique",weight: "bolder"} 4 $.jQuery.extend(Css1,Css2) 5 //结果:Css1的size属性被覆盖,而且继承了Css2的weight属性 6 // Css1 = {size: "12px",style: "oblique",weight: "bolder"} 7data:image/s3,"s3://crabby-images/64a08/64a080f982850d829b29efe9ab69bd404f7a6535" alt=""
3。深度镶套对象 新的extend()允许你更深度的合并镶套对象。下面的例子是一个很好的证明。
1 // 以前的 .extend() 2 jQuery.extend( 3data:image/s3,"s3://crabby-images/1d701/1d70146ac1f3016d52a6f84f755fc3859e7a8193" alt="" { name: “John”, location: { city: “Boston” } }, 4data:image/s3,"s3://crabby-images/1d701/1d70146ac1f3016d52a6f84f755fc3859e7a8193" alt="" { last: “Resig”, location: { state: “MA” } } 5 ); 6 // 结果: 7 // => { name: “John”, last: “Resig”, location: { state: “MA” } } 8 // 新的更深入的 .extend() 9 jQuery.extend( true, 10data:image/s3,"s3://crabby-images/1d701/1d70146ac1f3016d52a6f84f755fc3859e7a8193" alt="" { name: “John”, location: { city: “Boston” } }, 11data:image/s3,"s3://crabby-images/1d701/1d70146ac1f3016d52a6f84f755fc3859e7a8193" alt="" { last: “Resig”, location: { state: “MA” } } 12 ); 13 // 结果 14 // => { name: “John”, last: “Resig”, 15 // location: { city: “Boston”, state: “MA” } } 16data:image/s3,"s3://crabby-images/64a08/64a080f982850d829b29efe9ab69bd404f7a6535" alt="" 17data:image/s3,"s3://crabby-images/64a08/64a080f982850d829b29efe9ab69bd404f7a6535" alt=""
(责任编辑:admin) |