当前位置:文档之家› jQuery 核心函数以及jQuery对象

jQuery 核心函数以及jQuery对象

jQuery 核心函数以及jQuery对象
jQuery 核心函数以及jQuery对象

一、jQuery 核心函数

首先介绍jQuery 的几个核心函数,在jQuery 中它们起着至关重要的作用,在实际的前端开发过程中用到最多的也是它们。

1、jQuery(elements)

将一个或多个DOM元素转化为jQuery对象。

这个函数也可以接收XML文档和Window对象(虽然它们不是DOM元素)作为有效的参数。

返回值:jQuery 对象

参数

elements:用于封装成jQuery 对象的DOM 元素

复制代码代码如下:

// 将当前页面的背景色设为黑色

jQuery(document.body).css( "background-color", "black" );

再看以下代码

// 将当前页面的背景色设为黑色

$(document.body).css( "background-color", "black" );

代码也可以正常运行,并且执行的效果跟前面的代码一致;那么这儿的$ 和前面的jQuery 标识符到底有什么关系呢?

打开jQuery 的源文件jquery-1.3.2.js 发现以下代码

jQuery = window.jQuery = window.$ = function( selector, context ) {

// The jQuery object is actually just the init constructor 'enhanced'

return new jQuery.fn.init( selector, context );

}

原来$ 与jQuery 代表的是jQuery 框架中同一个function,使用jQuery 和$ 的效果是一样的;实际上jQuery 框架中采用$ 来作为jQuery 方法的一个别名(更易于使用),由于担心$ 与其它javascript 框架(比如https://www.doczj.com/doc/4510868111.html, ajax)甚至个人代码中的$ 标识符产生冲突,也可以通过jQuery.noConflict() 函数来移除$ 与jQuery 函数的关联,这样$ 就不代表jQuery 方法了,而是代表那个原始的$ 对象了。

2、jQuery(expression,[context])

这个函数接收一个包含CSS 选择器的字符串,然后用这个字符串去匹配一组元素。

jQuery 的核心功能都是通过这个函数实现的。jQuery中的一切都基于这个函数,或者说都是在以某种方式使用这个函数。这个函数最基本的用法就是向它传递一个表达式(通常由CSS 选择器组成),然后根据这个表达式来查找所有匹配的元素。

返回值:jQuery 对象

参数

expression:用来查找DOM 元素的字符串

context:(可选) 作为待查找的DOM 元素集、文档或jQuery 对象,用于限定查找范围

复制代码代码如下:

// 查找所有DIV 元素下的A 元素

$("div > a");

3、jQuery(html)

根据HTML 字符串,动态创建由jQuery 对象包装的DOM 元素。

返回值:jQuery 对象

参数

html:用于创建DOM 元素的HTML 字符串

复制代码代码如下:

// 将一个https://www.doczj.com/doc/4510868111.html, 的超链接元素加到页面主体元素中

$("https://www.doczj.com/doc/4510868111.html,").appendTo("body");

二、jQuery 对象

jQuery 核心函数的返回值都是一个jQuery 对象,通过对jQuery 对象进行操作,可以完成javascript 编程中的大部分任务;那么这个jQuery 对象到底是一个什么对象呢?

通过doc[0]、doc[1] 可以分别取出一个DOM 对象,其它的则是一些jQuery 对象特有的属性和方法;实际上jQuery 对象包装了DOM 对象,同时还包含了一些操作DOM 元素的jQuery 方法。

在使用jQuery 的过程中,大部分情况下第一步工作同时也是最重要的一步工作,就是取得包装了要操作DOM 对象的jQuery 对象;然后通过调用取得的jQuery 对象的方法来完成对DOM 对象的操作。

详细出处参考:https://www.doczj.com/doc/4510868111.html,/article/22688.htm

js和jquery获取父级元素、子级元素、兄弟元素的方法

原文地址: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),但是是查找所有祖先元素,不限于父元素

jQuery选择题

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代码,不能够让汉字“四”的颜色变成红色。(选一项) A、$("#header ul li:eq(3)").css("color","red"); B、$("#header li:eq(3)").css("color","red"); C、$("#header li:last").css("color","red"); D、$("#header li:gt(3)").css("color","red"); 5.在HTML页面中有如下结构的代码: