jQuery ajax ——一些细节以及主函数扩展出来的方法jQuery.ajaxSetup
我们可以从主函数看出,参数是通过jQuery.ajaxSetup产生的:
// 通过jQuery.ajaxSetup改造参数对象
s = jQuery.ajaxSetup( {}, options ),
那么jQuery.ajaxSetup在干些什么呢?
jQuery.ajaxSetup = function( target, settings ) {
// 如果有参数
return settings ?
// 创建一个设置对象,先将jQuery.ajaxSettings的属性放进去,
// 然后将参数也放进去
ajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) :
// 并将设置对象的属性放进jQuery.ajaxSettings对象里
ajaxExtend( jQuery.ajaxSettings, target );
};
ajaxExtend
ajaxExtend和jQuery.extend有一些不同,避免有些不需要深复制的属性进行深复制。
function ajaxExtend( target, src ) {
var key, deep,
flatOptions = jQuery.ajaxSettings.flatOptions || {};
// 遍历src对象中的所有key
for ( key in src ) {
// 如果值不是undefined
if ( src[ key ] !== undefined ) {
// 判断是不是不需要深复制的,如果不需要深复制,将属性直接写进target,
// 否则写进deep里存起来
// 我们可以从jQuery.ajaxSettings.flatOptions看到,
// 实际上不需要深复制的是url和context
( flatOptions[ key ] ? target : ( deep || (deep = {}) ) )[ key ] =src[ key ]; }
}
// 如果deep不是undefined,证明需要深复制
if ( deep ) {
// 开始深复制
jQuery.extend( true, target, deep );
}
// 返回target
return target;
}
ajaxHandleResponses
主体函数中response是通过ajaxHandleResponses来处理的:
// 得到响应数据
if ( responses ) {
// 通过ajaxHandleResponses处理数据
response = ajaxHandleResponses( s, jqXHR, responses );
}
我们来看看该函数干了些什么。
function ajaxHandleResponses( s, jqXHR, responses ) {
var ct, type, finalDataType, firstDataType,
contents = s.contents,
dataTypes = s.dataTypes,
responseFields = s.responseFields;
// 将responseXXX填入jqXHR指定位置,也就是responseXML或者responseText
// 其中jqXHR.xml对应responseXML,jqXHR.text对应responseText
for ( type in responseFields ) {
if ( type in responses ) {
jqXHR[ responseFields[type] ] = responses[ type ];
}
}
// 删除掉通配dataType,得到返回的Content-Type
while( dataTypes[ 0 ] === "*" ) {
dataTypes.shift();
if ( ct === undefined ) {
ct = s.mimeType || jqXHR.getResponseHeader("Content-Type");
}
}
// 看看是不是我们能处理的Content-Type,比如图片这类二进制类型就不好处理了
if ( ct ) {
// 实际上能处理的就是text、xml和json
for ( type in contents ) {
if ( contents[ type ] && contents[ type ].test( ct ) ) {
// 如果是这三种类型,则推入dataTypes里
dataTypes.unshift( type );
break;
}
}
}
// 如果dataTypes是我们想要的,也就是text、xml、json
if ( dataTypes[ 0 ] in responses ) {
// 则最终dataType就是这个了
finalDataType = dataTypes[ 0 ];
// 否则
} else {
// 尝试转换成我们要的dataType
for ( type in responses ) {
// 如果dataTypes[ 0 ]不存在,则直接用type作为最终dataType
// 否则,看看能不能转换,能的话就用type作为最终dataType
if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[0] ] ) {
finalDataType = type;
break;
}
// 保存第一个type
if ( !firstDataType ) {
firstDataType = type;
}
}
// 用最终dataType或者用第一个type
finalDataType = finalDataType || firstDataType;
}
// 如果有最终dataType
if ( finalDataType ) {
// 如果最终dataType不是dataTypes[ 0 ]
if ( finalDataType !== dataTypes[ 0 ] ) {
// 将finalDataType推入dataTypes队列里
dataTypes.unshift( finalDataType );
}
// 返回responses对应的finalDataType数据
return responses[ finalDataType ];
}
}
jQuery.fn.load
实际上有两个jQuery.fn.load,一个是类似于onload的方法,另一个则是载入指定html页面。
前一个是jQuery.fn.on的简单扩展,而后面一个则是使用jQuery.ajax方法的扩展。
jQuery.fn.load = function( url, params, callback ) {
// 如果url不是string,且_load存在
// 证明这是onload方法,则调用保存的_load方法
if ( typeof url !== "string" && _load ) {
return _load.apply( this, arguments );
}
var selector, type, response,
self = this,
off = url.indexOf(" ");
// 看看是不是载入指定元素,比如参数是'ajax/test.html #container'
if ( off >= 0 ) {
// 分隔出需要载入的元素
selector = url.slice( off, url.length );
// 分隔出真正的url
url = url.slice( 0, off );
}
// 模拟重载
if ( jQuery.isFunction( params ) ) {
// 如果是函数那么就当这个是回调函数
callback = params;
params = undefined;
// 如果参数是objects,那么定义type是POST
} else if ( params && typeof params === "object" ) {
type = "POST";
}
// 如果有需要修改的元素,开始请求
if ( self.length > 0 ) {
jQuery.ajax({
url: url,
// 如果type为undefined,那么就会缺省为GET方法
type: type,
dataType: "html",
data: params
// 完成后回调
}).done(function( responseText ) {
// 保存reponse
response = arguments;
// 对元素写入html
// 如果selector存在
self.html( selector ?
// 先用一个div来存储整个html页面的DOM,在找到selector的相关html jQuery("
// 否则直接用responseText
responseText );
// 如果回调函数存在,则回调
}).complete( callback && function( jqXHR, status ) {
self.each( callback, response || [ jqXHR.responseText, status, jqXHR ] );
});
}
return this;
};
jQuery.get & jQuery.post
这两个方法实际上就是通过jQuery.ajax扩展而来的。
// 加上get和post方法
jQuery.each( [ "get", "post" ], function( i, method ) { // jQuery.get或jQuery.post为
jQuery[ method ] = function( url, data, callback, type ) { // 模拟重载
if ( jQuery.isFunction( data ) ) {
type = type || callback;
callback = data;
data = undefined;
}
// 利用jQuery.ajax完成任务
return jQuery.ajax({
url: url,
type: method,
dataType: type,
data: data,
success: callback
});
};
});
jQuery.getScript & jQuery.getJSON
jQuery.getScript和jQuery.getJSON则是由jQuery.get扩展而来的。
jQuery.getScript = function( url, callback ) {
return jQuery.get( url, undefined, callback, "script" ); };
jQuery.getJSON = function( url, data, callback ) { return jQuery.get( url, data, callback, "json" );
}
原文地址:js和jquery获取父级元素、子级元素、兄弟元素的方法作者:草根gis 先说一下JS的获取方法,其要比JQUERY的方法麻烦很多,后面以JQUERY的方法作对比。 JS的方法会比JQUERY麻烦很多,主要则是因为FF浏览器,FF浏览器会把你的换行也当最DOM元素 原生的JS获取ID为test的元素下的子元素。可以用: var a = docuemnt.getElementById("test").getElementsByTagName_r("div"); 这样是没有问题的 此时a.length=2; 但是如果我们换另一种方法 var b =document.getElementByIdx_x("test").childNodes; 此时b.length 在IE浏览器中没问题,其依旧等于2,但是在FF浏览器中则会使4,是因为FF把换行也当做一个元素了。 所以,在此,我们就要做处理了,需遍历这些元素,把元素类型为空格而且是文本都删除。 functiondel_ff(elem){ varelem_child = elem.childNodes; for(vari=0; i< p=""> if(elem_child[i].nodeName == "#text" && !/s/.test(elem_child.nodeValue)) {elem.removeChild(elem_child)
} } } 上述函数遍历子元素,当元素里面有节点类型是文本并且文本类型节点的节点值是空的。就把他删除。 nodeNames可以得到一个节点的节点类型,/s/是非空字符在JS里的正则表达式。前面加!,则表示是空字符 test() 方法用于检测一个字符串是否匹配某个模式.语法是:RegExpObject.test(string) 如果字符串string 中含有与RegExpObject 匹配的文本,则返回true,否则返回false。 nodeValue表示得到这个节点里的值。 removeChild则是删除元素的子元素。 之后,在调用子,父,兄,这些属性之前,调用上面的函数把空格清理一下就可以了 下面介绍JQUERY的父,子,兄弟节点查找方法 jQuery.parent(expr) 找父亲节点,可以传入expr进行过滤,比如$("span").parent()或者$("span").parent(".class") jQuery.parents(expr),类似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素
1.以下关于jQuery的描述错误的是()。(选一项) A、jQuery 是一个 JavaScript 函数库 B、jQuery 极大地简化了 JavaScript 编程 C、jQuery 的宗旨是“write less,do more” D、jQuery的核心功能不是根据选择器查找HTML元素,然后对这些元素执行相应的操作 2.在jQuery中,下列关于文档就绪函数的写法错误的是()。(选一项) A、$(document).ready(function() { }); B、$(function() { }); C、$(document)(function() { }); D、$().ready(function() { }); 3.以下()选项不能够正确地得到这个标签:(选一项) A、$("#btnGo") B、$(".btnGo") C、$(".btn") D、$("input[type='button']") 4.在HTML页面中有如下结构的代码:
jQuery常用方法中文解析 jQuery设计思想 【目录】 一、选择网页元素 二、改变结果集 三、链式操作 四、元素的操作:取值和赋值 五、元素的操作:移动 六、元素的操作:复制、删除和创建 七、工具方法 八、事件操作 九、特殊效果 一、选择网页元素 jQuery的基本设计和主要用法,就是"选择某个网页元素,然后对其进行某种操作"。这是它区别于其他函数库的根本特点。使用jQuery的第一步,往往就是将一个选择表达式,放进构造函数jQuery()(简写为$),然后得到被选中的元素。选择表达式可以是CSS选择器: $(document) //选择整个文档对象 $('#myId') //选择ID为myId的网页元素 $('div.myClass') // 选择class为myClass的div元素 $('input[name=first]') // 选择name属性等于first的input元素 也可以是jQuery特有的表达式: $('a:first') //选择网页中第一个a元素 $('tr:odd') //选择表格的奇数行 $('#myForm :input') // 选择表单中的input元素 $('div:visible') //选择可见的div元素 $('div:gt(2)') // 选择所有的div元素,除了前三个 $('div:animated') // 选择当前处于动画状态的div元素
二、改变结果集 如果选中多个元素,jQuery提供过滤器,可以缩小结果集: $('div').has('p'); // 选择包含p元素的div元素 $('div').not('.myClass'); //选择class不等于myClass的div元素 $('div').filter('.myClass'); //选择class等于myClass的div元素 $('div').first(); //选择第1个div元素 $('div').eq(5); //选择第6个div元素 有时候,我们需要从结果集出发,移动到附近的相关元素,jQuery也提供了在DOM树上的移动方法: $('div').next('p'); //选择div元素后面的第一个p元素 $('div').parent(); //选择div元素的父元素 $('div').closest('form'); //选择离div最近的那个form父元素 $('div').children(); //选择div的所有子元素 $('div').siblings(); //选择div的同级元素 三、链式操作 选中网页元素以后,就可以对它进行某种操作。jQuery允许将所有操作连接在一起,以链条的形式写出来,比如: $('div').find('h3').eq(2).html('Hello'); 分解开来,就是下面这样: $('div') //找到div元素 .find('h3') //选择其中的h3元素 .eq(2) //选择第3个h3元素 .html('Hello'); //将它的内容改为Hello 这是jQuery最令人称道、最方便的特点。它的原理在于每一步的jQuery操作,返回的都是一个jQuery对象,所以不同操作可以连在一起。jQuery还提供了.end()方法,使得结果集可以后退一步: $('div').find('h3').eq(2).html('Hello').end() //退回到选中所有的h3元素的那一步.eq(0) //选中第一个h3元素.html('World'); //将它的内容改为World
jQuery常用功能大全 1、关于页面元素的引用 通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery 对象(集合对象),不能直接调用dom定义的方法。 2、jQuery对象与dom对象的转换 只有jquery对象才能使用jquery定义的方法。注意dom对象和jquery对象是有区别的,调用方法时要注意操作的是dom对象还是jquery对象。 普通的dom对象一般可以通过$()转换成jquery对象。 如:$(document.getElementByIdx_x("msg"))则为jquery对象,可以使用jquery的方法。 由于jquery对象本身是一个集合。所以如果jquery对象要转换为dom对象则必须取出其中的某一项,一般可通过索引取出。 如:$("#msg")[0],$("div").eq(1)[0],$("div").get()[1],$("td")[5]这些都是dom对象,可以使用dom中的方法,但不能再使用Jquery的方法。 以下几种写法都是正确的: $("#msg").html(); $("#msg")[0].innerHTML; $("#msg").eq(0)[0].innerHTML; $("#msg").get(0).innerHTML; 3、如何获取jQuery集合的某一项 对于获取的元素集合,获取其中的某一项(通过索引指定)可以使用eq或get(n)方法或者索引号获取,要注意,eq返回的是jquery 对象,而get(n)和索引返回的是dom元素对象。对于jquery对象只能使用jquery的方法,而dom对象只能使用dom的方法,如要获取第三个
jQuery入门[1]-构造函数 https://www.wendangku.net/doc/5f4900738.html,/archive/2008/03/05/1091816.html jQuery优点 ?体积小(v1.2.3 15kb) ?丰富的DOM选择器(CSS1-3 + XPath) ?跨浏览器(IE6,FF,Safari,Opera) ?链式代码 ?强大的事件、样式支持 ?强大的AJAX功能 ?易于扩展,插件丰富 jQuery的构造函数接收四种类型的参数: jQuery(expression,context) jQuery(html) jQuery(elements) jQuery(fn) 第一种根据表达式(ID,DOM元素名,CSS表达式,XPath表达式)找出文档中的元素,并组装成一个jQuery对象返回。 DEMO: DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.wendangku.net/doc/5f4900738.html,/TR/xhtml1/DTD/xhtml1-transitional.dtd">