一、简单的一些介绍

1.jQuery是由普通的是由一些系列操作DOM节点的函数和一些其他的工具方法组成的js库。

2.为什么要使用jQuery库?

  jQuery面向用户良好的设计在使用过程中彻底解放了记忆原生操作DOM的接口。

  jQuery中包含了可重用的函数,用来辅助我们简化JavaScript开发。

  jQuery在半数以上并没有复杂交互的网站中得以大量使用,因为他们需要的仅仅是一些兼容低级浏览器又有炫酷效果动画的页面。

  jQuery改变了数百万人编写JavaScript的方式,当然部分人已经觉得时过境迁,组件化,工程化大行其道,但不要忘记jQuery对前端开发者的启蒙意义!且很多公司项目依然需要使用。

3.jQuery注意点:

  jQuery知识辅助工具,不能完全替代js,二者并存的方式出现在项目中;

  jQuery很庞杂,先学使用再学思想。

  jQuery方法很多,按需学习,把常用的学透彻。

  jQuery API使用时可以现查现用,不难理解。

4.引入jQuery库:cdn:http://www.jq22.com/cdn/#a2

5.jQuery官网:中文:https://www.jquery123.com/英文原版:https://jQuery.com/

 二、jQuery核心函数

在jQuery的应用开发中,我们经常看到这样的代码;

$("div .container").css("display","none"); //将div节点下样式值为container的节点设置为不显示
var width = $("div .container").width(); //得到div节点下样式值为container的宽度
var html = $(document.getElementById("result")).html(); //得到id为result的节点的innerHTML值
$("#result", document.forms[0]).css("color", "red"); //将在第一个Form节点下id为result的字体颜色设置为红色
$("<div>hello,world</div>").appendTo("#result"); //将HTML字符串信息 内部追加到 id为result的节点末尾

这里我们只关注jQuery的使用,不对源码进行分析,如需了解源码可以参考jQuery源码解析对象实例化与jQuery原型

那么jQuer(...)里面的参数是什么?这个方法就可以实现什么呢?

<div class="a">...</div>
<ul>
<li>1</li>
<li>2</li>
</ul>
<p id="b">...</p>
<script>
$(function(){
console.log($(".a"););//获取类名为a的元素(这里含元素div)的一个jQuery对象类数组
console.log($("ul li"););//获取ul元素下的li的所有元素构成的jQuery对象类数组
console.log($("#b"););//获取id为b的元素(这里是p元素)的jQuery对象。
});
</script>

$(...)的作用:

1.构建一个独立的jQuery代码块(作用域),参数一个function;

2.通过选择器构建jQuery元素节点对象和元素节点对象类数组。

3.还可以通过一个或多个DOM元素对象作为参数构建该元素的jQuery对象或对象类数组  

$(...)的参数及容错机制:

当我们给$(...)传入null或者undefined,又或者传入的选择器字符串有误或者匹配不到元素的情况下,并不会报错,而是返回一个空的jQuery对象。

在构建独立的jQuery作用域时,浏览器对文件加载实现异步机制,jQuery再执行构建作用域前需要DOMContenLoaded(dom加载完毕)事件触发后再执行构建。所以为了保证jQuery代码顺利执行,jQuery会通过延迟机制触发window.onload事件,直到jQuery代码顺利执行。

三、jQuery选择器

(jQuery选择器的核心sizzle并不是并不是jQuery开发的,在这里为了让不是很了解内部源码的客官造成困扰,jQuery的选择器相较于css选择成为jQuery独有。)

1.jQuery常用选择器有ID选择器,类选择器,标签选择器,分组选择器,部分属性选择器,及父子选择器和并列选择器都基本与CSS选择器一致。这里对属性选择器做一些说明以外,其他选择器可以到我的另一篇博客了解学习总结:CSS(一)定义方式、选择器、选择器权重

2.jQuery的属性选择器:jQuery的属性选择相对于css的属性选择器少了两个,下标四个选择器就是jQuery的属性选择器。

 [attribute] $("[href]") 所有带有href属性的元素
 [attribute=value] $("href='#'") 所有href属性的值等于"#"的元素
 [attribute!=value] $("href!='#'") 所有href属性的值不等于"#" 的元素。
 [attribute$=value] $("href$='.jpg'") 所有href属性的值包含以".jpg" 结尾的元素。
 [attribute^=value] $("htef^='atr'") 所有href属性的值包含以"atr"开头的元素。

3.奇偶选择器与首尾选择器:这几种选择器是jQuery独有的选择器,这种奇偶首尾选择器是对jQuery对象类数组下标的一种操作。

 :first  $("p:first")  第一个<p>元素
 :last  $("p:last")  最后一个<p>元素
 :even  $("tr:even")  所有偶数<tr>元素
 :odd  $("tr:odd")  所有奇数<tr>元素

3.比较选择器与eq选择器:这几个选择器也同上面的一样,都是在匹配的基础上通过类数组的脚标来实现筛选。

 :eq(index)  $("ul li:(3)")  列表中的第四个元素(index从0开始)
 :gt(no)  $("ul li:gt(3)")  列出index大于3的元素
 :lt(no)  $("ul li:lt(3)")  列出index小于3的元素
 :not(selector)  $("input:not(:empty)")  所有不为空的input元素(:empty表示无子(元素)节点的所有元素)

这里就介绍这里比较常用的选择器,还有一些不常用的选择器如果需要了解可以访问W3C官方jQuery参考手册

 四、选择元素的方法

1.get()方法: get(index)--通过指定jQuery的DOM对象集合(类数组)的索引获取指定元素。索引值可以是下标(从0开始正向索引),也可以是负数(从-1开始反向索引)。不写参数的情况下就会返回整个jQuery的DOM对象集合的原生DOM集合(数组)。

<div class="demo">1</div>
<div class="demo">2</div>
<div class="demo">3</div>
<div class="demo">4</div>
<div class="demo">5</div>
//js代码
console.log($('.demo').get(1));//<div class="demo">2</div>
console.log($('.demo').get(-1));//<div class="demo">5</div>
console.log($('.demo').get());//返回原生DOM集合(数组)

2.eq()方法:eq(index)--通过指定jQuery的DOM对象集合(类数组)的索引获取指定元素的jQuery对象,索引规则与get一致。

console.log($('.demo').eq(1));//
console.log($('.demo').eq(-1));//
console.log($('.demo').eq());//

这里上传一份仿写简版的jQuery代码,以供深入理解get和eq的原理:

/**
* MyjQuery.js-1-2
* jQuery使用精髓 - 选择元素 - 循环操作 - 链式调用
* 实现--get方法
* 实现--eq方法
**/
(function(window,undefined){
//定义jQuery函数(接口方法)
function jQuery(selector){
return new jQuery.prototype.init(selector);
}
//构建jQuery对象构造函数
jQuery.prototype.init = function(selector){
//选出dom 并且包装成jQuery对象 返回
// id css
this.length = 0;
//当获取的selector $()-$(null)--eq()-eq(null)这种情况时
if(selector == null){
return this;
}
if(typeof selector == 'string' && selector.indexOf('.') != -1){
var dom = document.getElementsByClassName(selector.slice(1));
}else if(typeof selector == 'string' && selector.indexOf('#') != -1){
var dom = document.getElementById(selector.slice(1));
}
// if(selector instanceof Element){
// this[0] = selector;
// }
//将获取到的dom节点添加到jQuery对象上
if(selector instanceof Element || dom.length == undefined){ //--通过id获取到的dom只有一个节点没有length属性
this[0] = dom || selector;
this.length++;
}else{//--通过类获取到的dom节点集合本身就会有length属性
for(var i = 0; i < dom.length; i++){
this[i] = dom[i];
this.length++;
}
}
}
//给jQuery原型上添加工具方法
//--css操作方法
jQuery.prototype.css = function(config){
for(var i = 0; i < this.length; i++){
for(var attr in config){
this[i].style[attr] = config[attr];
}
}
//链式操作
return this;
}
//--get操作方法
jQuery.prototype.get = function(num){
// if(num == null){
// return [].slice.call(this,0);
// }else{
// if(num >= 0){
// return this[num];
// }else{
// return this[num + this.length];
// }
// }
//三目运算符实现逻辑
return num != null ? (num >= 0 ? this[num] : this[num + this.length]) : [].slice.call(this,0);
}
//--eq操作方法
jQuery.prototype.eq = function(num){
var dom = num != null ? (num >= 0 ? this[num] : this[num + this.length]) : null;
return jQuery(dom);
}
//将init原型(构造函数的原型)指向jQuery的原型
//实现了在jQuery原型定义工具方法,也是每个构造出来的实例对象的原型上的方法
jQuery.prototype.init.prototype = jQuery.prototype;
//设置jQuery的接口
window.$ = window.jQuery = jQuery;
})(window);

仿写jQuery源码

3.基于sezzleJS选择元素的方法:find、filter、not、has、is,sezzleJS是一个基于css选择器的js元素选择器脚本,是由第三方团队开发,并非jQuery团队开发的,很多开发js脚本都是基于sezzleJS的选择器来实现的,有意向开发自己的脚本库的小伙伴可以考虑深入研究这一块技术,这里我就不对sezzleJS做剖析,仅仅对这些方法做一些应用介绍。

find()方法:获取当前节点的所有后辈元素(子、孙、曾孙...),参数可以是元素选择器和jQuery对象。

<div class="wrapper">
<ul>
<li>1</li>
<li>2<span>span1</span></li>
<li class="demo">3</li>
<li>4<p><span>span2</span></p></li>
<li class="demo">5</li>
</ul>
</div>
//js代码
$('.wrapper').css({position:'relative'})
.find('ul').css({listStyle:'none'})
.find('li').css({color:'red'});
$('.wrapper').find('span').css({fontSize:'25px'});

find及很多dom节点遍历操作都是基于jQuery对象的prevObject属性来实现的,jQuery对象通过这个属性来保存当前的jQuery对象,是从哪个jQuery对象的DOM上下文获取的。

console.log($('.wrapper').prevObject);//document
console.log($('.wrapper').find('ul').prevObject);//div
console.log($('.wrapper').find('ul').find('li').prevObject);//ul

filter()方法:过滤函数--从指定的DOM节点集合中筛选出指定的DOM点。参数 css selector jquery--指向DOM集合中的部分DOM,jQuery选择器奇偶首尾选择器属于常用配合--first、last、even、odd。

console.log( $('.wrapper ul').find('li').filter('.demo') );
console.log( $('.wrapper ul').find('li:last') );//最后一个li

not()方法:的效果就是filter执行结果的反集

console.log( $('.wrapper ul').find('li').not(':even'));//除了下标为偶数的li,包括0

has()方法:has方法与filter方法非常类似,filter通过DOM节点的自身的类或特性来筛选,has通过识别节点拥有某些子节点来筛选自己(参数为选择器或者元素节点)。

console.log($('.wrapper ul').find('li').has('span,p'));//筛选到含有子节点span和p元素的li

is()方法:用来检测一个jQuery对象中的DOM(集合)是否含有某个指定的元素,如果有就返回true。

console.log( $('.wrapper ul').find('li').is('.demo') );
//li的jQuey对象元素集合中有li元素包含有class为demo的li,返回true

4.jQuery链式调用(串联):合并、回退与pushStack

add()方法:将新匹配到的元素节点集与当前元素节点集合并,参数可以是任何jQuery选择器,在产生DOM节点重复合并时,合并的结果里不会出现重复的节点。

console.log($('div').add('.wrapper'));
console.log($('.demo').add('.wrapper'));

end()方法:回退到当前jQuery对象的上一个jQuery对象,也就是产生当前jQuery对象的父对象。如果当前jQuery对象是最初的对象,则返回当前文档document的jQuery对象。

console.log($('.wrapper').end());//document
console.log($('.wrapper').find('li').end());//wrapper

end方法有一次基于jQuery的prevObject属性来实现了,其实前面在find部分介绍prevObject属性并不完全合适,在那个阶段至add都是写入prevObject的属性值,真正应用这个值的时候是end方法。这里我们可以模仿jQuery源码来实现自己MyjQuery的链式调用功能。(注意add仿写功能并没有对重复节点进行处理)

(function(window,undefined){
//定义jQuery函数(接口方法)
function jQuery(selector){
return new jQuery.prototype.init(selector);
}
//构建jQuery对象构造函数
jQuery.prototype.init = function(selector){
//选出dom 并且包装成jQuery对象 返回
// id css
this.length = 0;
this.prevObject = document;
//当获取的selector $()-$(null)--eq()-eq(null)这种情况时
if(selector == null){
return this;
}
if(typeof selector == 'string' && selector.indexOf('.') != -1){
var dom = document.getElementsByClassName(selector.slice(1));
}else if(typeof selector == 'string' && selector.indexOf('#') != -1){
var dom = document.getElementById(selector.slice(1));
}
// if(selector instanceof Element){
// this[0] = selector;
// }
//将获取到的dom节点添加到jQuery对象上
if(selector instanceof Element || dom.length == undefined){ //--通过id获取到的dom只有一个节点没有length属性
this[0] = dom || selector;
this.length++;
}else{//--通过类获取到的dom节点集合本身就会有length属性
for(var i = 0; i < dom.length; i++){
this[i] = dom[i];
this.length++;
}
}
}
//给jQuery原型上添加工具方法
//--css操作方法
jQuery.prototype.css = function(config){
for(var i = 0; i < this.length; i++){
for(var attr in config){
this[i].style[attr] = config[attr];
}
}
//链式操作
return this;
} jQuery.prototype.pushStack = function(dom){
if( !dom || dom.constructor != jQuery){
dom = jQuery(dom); }
dom.prevObject = this;
return dom;
} //--get操作方法
jQuery.prototype.get = function(num){
// if(num == null){
// return [].slice.call(this,0);
// }else{
// if(num >= 0){
// return this[num];
// }else{
// return this[num + this.length];
// }
// }
//三目运算符实现逻辑
return num != null ? (num >= 0 ? this[num] : this[num + this.length]) : [].slice.call(this,0);
}
//--eq操作方法
jQuery.prototype.eq = function(num){
var dom = num != null ? (num >= 0 ? this[num] : this[num + this.length]) : null;
return this.pushStack(dom);
}
//--add合并操作
jQuery.prototype.add = function(selector){
var curObj = jQuery(selector);
var baseObj = this;
var newObje = jQuery(); for(var i = 0; i < curObj.length; i++){
newObje[newObje.length++] = curObj[i];
}
for(var i = 0; i < baseObj.length; i++){
newObje[newObje.length++] = baseObj[i];
}
//newObje.prevObject = this;
this.pushStack(newObje);
return newObje;
}
//--end回退功能
jQuery.prototype.end = function(){
return this.prevObject;
} //将init原型(构造函数的原型)指向jQuery的原型
//实现了在jQuery原型定义工具方法,也是每个构造出来的实例对象的原型上的方法
jQuery.prototype.init.prototype = jQuery.prototype;
//设置jQuery的接口
window.$ = window.jQuery = jQuery;
})(window);

仿写jQuery源码

这部分源码重点用来来说明jQuery的链式调用原理,涉及节点获取链式指向prevObject和样式方法的放回this,其中jQuery中的end方法和pushStack值得我们借鉴。

最后还有一个节点获取方法slice()用来获取当前节点的子节点,这个方法和find是有区别的,find()是用来获取全部后代元素节点,slice()只是用来获取子节点而已。

jQuery使用(一):jQuery对象与选择器的更多相关文章

  1. jQuery学习-什么是jquery? Js与jquery之间的关系 Jquery选择器

    1.  什么是jQuery以及学习的意义等 jQuery是一个js库 JS库是什么? 把常用的方法,进行封装,封装到一个单独的js文件当中,要用的时候直接调用. 学习jQuery主要学什么? 学习jQ ...

  2. jquery总结01-基本概念和选择器

    dom元素和jquery元素的区别 dom元素支持dom元素自带的属性和方法,jquery元素支持jquery元素自带的属性和方法 dom                  var div = doc ...

  3. JQuery源码之“对象的结构解析”

    吃完午饭,觉得有点发困,想起了以后我们的产品可能要做到各种浏览器的兼容于是乎不得不清醒起来!我们的web项目多数是依赖于Jquery的.据了解,在Jquery的2.0版本以后对IE的低端版本浏览器不再 ...

  4. 浅析jQuery框架与构造对象

    这是一些分析jQuery框架的文字    面向的读者应具备以下要求 1.非常熟悉HTML 2.非常熟悉javascript语法知识 3.熟悉javascript面向对象方面的知识 4.熟练使用jQue ...

  5. jquery学习(3)--高级选择器

    自己手写的学习笔记.常规选择器: /****************学习--高级选择器(1)****************/---高级选择器:ie7+ 层次选择器: 后代选择器     ul li ...

  6. 彻底抛弃PeopleEditor,SharePoint中利用Jquery Chosen创建新的人员选择器

    彻底抛弃PeopleEditor,SharePoint中利用Jquery Chosen创建新的人员选择器 基于SharePoint平台开发时,人员选择器使用频率是非常高的,但是原生的人员选择器使用太麻 ...

  7. JQuery(一)---- JQ的选择器,属性,节点,样式,函数等操作详解

    JQuery的基本概念 JQuery是一个javascript库,JQuery凭借着简洁的语法和跨平台的兼容性,极大的简化了js操作DOM.处理事件.执行动画等操作.JQuery强调的理念是:'wri ...

  8. Jquery 使用和Jquery选择器

    jQuery中的顶级对象($) jQuery 中最常用的对象即 $ 对象,要想使用 jQuery 的方法必须通过 $ 对象.只有将普通的 Dom 对象封装成 jQuery 对象,然后才能调用 jQue ...

  9. python 全栈开发,Day53(jQuery的介绍,jQuery的选择器,jQuery动画效果)

    js总结 js: 1.ECMAScript5 ES5语法 2.DOM CRUD 获取 3种方式 id tag className //面向对象 对象 : 属性和方法 某个对象中 function $( ...

随机推荐

  1. 【BZOJ4042】【CERC2014】parades 状压DP

    题目大意 给你一棵\(n\)个点的树和\(m\)条路径要求你找出最多的路径,使得这些路径不共边.特别的,每个点的度数\(\leq 10\). \(n\leq 1000,m\leq \frac{n(n- ...

  2. MT【297】任意四边形的一个向量性质

    在平面四边形$ABCD$中,已知$E,F,G,H$分别是棱$AB,BC,CD,DA$的中点,若$|EG|^2-|HF|^2=1,$设$|AD|=x,|BC|=y,|AB|=z,|CD|=1,$则$\d ...

  3. UOJ #207. 共价大爷游长沙(LCT + 异或哈希)

    题目 维护一颗动态树,并维护一个点对集合 \(S\) . 动态查询一条边,是否被集合中所有点对构成的路径包含. \(n \le 100000, m \le 300000\) 题解 orz 前辈 毛爷爷 ...

  4. ubuntu “无法获得锁 /var/lib/dpkg/lock -open”

    在ubuntu系统终端下,用apt-get install 安装软件的时候,如果在未完成下载的情况下将终端中断,此时 apt-get进程可能没有结束.结果,如果再次运行apt-get install ...

  5. CSS之FLex布局介绍

    网页布局(layout)是CSS的一个重点应用. img 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如, ...

  6. 【原创】hdu 1166 敌兵布阵(线段树→单点更新,区间查询)

    学习线段树的第三天...真的是没学点啥好的,又是一道水题,纯模板,我个人觉得我的线段树模板还是不错的(毕竟我第一天相当于啥都没学...找了一整天模板,对比了好几个,终于找到了自己喜欢的类型),中文题目 ...

  7. Arch Linux中使用VMware Workstation不能打开vmmon内核模块

    打开VMware Workstation出现错误提示:Could not open /dev/vmmon: No such device.Please make sure that the kerne ...

  8. A1099. Build A Binary Search Tree

    A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...

  9. mysql建立索引的几大原则

    (转)仅供自己学习,特此记录 1.选择唯一性索引 唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录.例如,学生表中学号是具有唯一性的字段.为该字段建立唯一性索引可以很快的确定某个学生的信息 ...

  10. Spring3 (事务管理)

    简介: 1.事务管理.2.整合Junit.3.整和Web 1       事务管理 1.1   回顾事务 l  事务:一组业务操作ABCD,要么全部成功,要么全部不成功. l  特性:ACID 原子性 ...