标签:var 调用 led boa dom blog bar 难点 参数
1 /*重写Jquery中的ajax 封装壳*/ 2 $(function () { 3 (function ($) { 4 //首先备份下jquery的ajax方法 5 var _ajax = $.ajax; 6 7 //重写jquery的ajax方法 8 $.ajax = function (opt) { 9 //备份opt中error和success方法 10 var fn = { 11 beforeSend: function (XHR) { }, 12 error: function (XMLHttpRequest, textStatus, errorThrown) { }, 13 success: function (data, textStatus) { }, 14 complete: function (XHR, TS) { } 15 } 16 17 if (opt.beforeSend) { 18 fn.beforeSend = opt.beforeSend; 19 } 20 if (opt.error) { 21 fn.error = opt.error; 22 } 23 if (opt.success) { 24 fn.success = opt.success; 25 } 26 if (opt.complete) { 27 fn.complete = opt.complete; 28 } 29 30 31 32 //扩展增强处理 33 var _opt = $.extend(opt, { 34 //全局允许跨域 35 xhrFields: { 36 withCredentials: true 37 }, 38 error: function (XMLHttpRequest, textStatus, errorThrown) { 39 //错误方法增强处理 40 fn.error(XMLHttpRequest, textStatus, errorThrown); 41 }, 42 success: function (data, textStatus) { 43 //成功回调方法增强处理 44 fn.success(data, textStatus); 45 }, 46 beforeSend: function (XHR) { 47 //提交前回调方法 48 fn.beforeSend(XHR); 49 }, 50 complete: function (XHR, TS) { 51 //请求完成后回调函数 (请求成功或失败之后均调用)。 52 fn.complete(XHR, TS); 53 } 54 }); 55 if (opt.xhrFields) { 56 _opt.xhrFields = opt.xhrFields; 57 } 58 59 //调用native ajax 方法 60 return _ajax(_opt); 61 }; 62 })(jQuery); 63 });
往下翻页之前,有必要了解以下知识:
第一个括号里边的function($){….}实际上就是一个匿名函数,它的形参是$,这很奇怪,其实这里主要是为了不与其它的库冲突。我们在调用函数的时候,通常都是函数名后边加上括号以及实参,但是由于操作符的优先级我们定义的匿名函数也需要用()括起来,所以就有了前面的(function($){....})。
现在这句代码什么意思大家应该很清楚了:第一个括号表示定义了一个匿名函数,然后(jQuery)表示为该函数传递的参数,整个结合起来意思就是,定义了一个匿名函数,然后又调用该函数,并传递实参jQuery,相当于——function fun($){…};fun(jQuery);
这种方法多用于存放开发的插件,执行其中的代码时,Dom对象并不一定加载完毕。于此相反的是$(function(){}),这种方法在使用时页面的Dom对象已经加载完毕了。事实上该方法的全写是:$(document).ready(function(){});
jQuery为开发插件提拱了两个方法,分别是:
jQuery.fn.extend(object);//为jQuery的实例对象添加方法
jQuery.extend(object);//为jQuery类本身扩展,添加新的方法或覆盖原有的方法
在jQuery中有如下源码:
由此看来jQuery.fn=jQuery.prototype,然而prototype是什么呢?
此方式则表示为jQuery类添加类方法(虽然jQuery没有类的概念,但用类来理解似乎简单了不少),或者直接理解为添加静态方法,然后就可以直接用$在其他地方来调用此扩展方法了,example:
这两个概念也是有必要知道的,详见我转载的文章:点击这里
标签:var 调用 led boa dom blog bar 难点 参数
原文地址:https://www.cnblogs.com/micro-chen/p/9213833.html