前端之jQuery基础

  • 基本概念

  • 选择器

  • 样式操作

  • 动画

  • 属性操作

  • 事件机制

  • jQuery插件机制

  • jQuery封装(面向对象)

 

1. jQuery基本介绍

1.1 为什么要学jQuery

使用JS操作DOM的时候,会遇到以下的一些缺点:

 

//1. 获取元素的方法太少且长,麻烦。
//2. 遍历伪数组很麻烦,通常要嵌套一大堆的for循环。
//3. 注册的事件会覆盖。
//4. 有兼容性问题。
//5. 实现动画很麻烦

 1.2 初体验

$(document).ready(function () {
    $("#btn1").click(function () {
      	//隐式迭代:偷偷的遍历,在jQuery中,不需要手动写for循环了,会自动进行遍历。
        $("div").show(200);
    });
    $("#btn2").click(function () {
        $("div").text("我是内容");
    });
});

使用jQuery的优点 :

//1. 获取元素的方式非常的简单,而且非常的丰富
//2. jQuery的隐式迭代特性,不再需要书写for循环语句。
//3. 使用jQuery完全不用考虑兼容性问题。
//4. jQuery提供了一系列动画相关的函数,使用非常方便。
//5. 代码简单、粗暴。

1.3 什么是jQuery?

jQuery是一个快速的、轻量的、功能丰富的js库。

jQuery的官网 http://jquery.com/

jQuery就是一个js库,使用jQuery的话,会比使用JavaScript更简单。

js库:把一些常用到的方法写到一个单独的js文件,使用的时候直接去引用这js文件就可以了。(animate.js、common.js)

1.4 使用步骤

引包(引入js文件)

<script src="jquery-1.11.1.js"></script>

入口函数

$(document).ready(function () {
});

$(function(){
    
});

功能实现

$("#btnShowDiv").click(function () {
	$("div").show(1000);
});

1.5 版本介绍

官网下载地址:http://jquery.com/download/

jQuery版本有很多,分为1.x 2.x 3.x

大版本分类:

1.x版本:能够兼容IE678浏览器(最终版本1.12.4)
2.x版本:不兼容IE678浏览器(最终版本2.2.4)

//jQuery目前正在更新的版本
3.x版本:不兼容IE678,更加的精简(在国内不流行,因为国内使用jQuery的主要目的就是兼容IE678),3.x版本只是在原来的基础上增加了一些新的特性。

关于压缩版和未压缩版 :

jquery-1.12.4.min.js:压缩版本,适用于生产环境,因为文件比较小,去除了注释、换行、空格等东西,但是基本没有可阅读性。
jquery-1.12.4.js:未压缩版本,适用于学习与开发环境,源码清晰,易阅读。

1.6 入口函数

入口函数的好处:

1. 等待文档加载完成,保证能够获取到元素
2. 形成了一个沙箱,防止全局变量污染。

两种写法:

//第一种写法
$(document).ready(function() {
	
});
//第二种写法
$(function() {
	
});

//js入口函数
window.onload = function(){
...
}

jQuery入口函数与js入口函数的对比 :

1.	JavaScript的入口函数要等到页面中所有资源(包括图片、文件)加载完成才开始执行。
2.	jQuery的入口函数只会等待文档树加载完成就开始执行,并不会等待图片、文件的加载。

1.7 jQuery对象与DOM对象(重点)

基本概念:

1. DOM对象:使用JavaScript中的方法获取页面中的元素返回的对象就是dom对象。
2. jQuery对象:jquery对象就是使用jquery的方法获取页面中的元素返回的对象就是jQuery对象。
3. jQuery对象其实就是DOM对象的包装集(包装了DOM对象的集合(伪数组))

jQuery对象与DOM对象的区别:

1. DOM对象与jQuery对象的方法不能混用。
2. DOM对象可以和jQuery对象相互转化


// dom对象
通过原生js方法获取到的元素就是dom对象
document.getElementById、document.getElementsByTagName
dom对象只能使用dom对象本身的属性和方法,不能使用jq提供的方法
       
// jq对象
通过jq提供的$() 方法获取到的元素就是jq对象
jq对象是一个伪数组,伪数组里面以下标的形式存储着获取到所有的dom对象
jq对象只能使用jq提供的方法,不能使用dom对象的方法

DOM对象转换成jQuery对象:【联想记忆:花钱】

var $obj = $(domObj);
// $(document).ready(function(){});就是典型的DOM对象转jQuery对象

jQuery对象转换成DOM对象:

var $li = $(“li”);
//第一种方法(推荐使用)
$li[0]
//第二种方法
$li.get(0)
// $: 哪里来,jq文件提供的
// $: 是个函数
// $的作用
// 功能比较强大,参数不同,作用就不同
// 1. 参数是函数,  $(function(){}),,   作用是入口函数
// 2. 参数是选择器,$("div"),,          作用是获取页面上的元素
// 3. 参数是dom对象  $(document)        作用是dom对象转jq对象

隔行变色案例:

<script src="./jquery-1.12.4.js"></script>
    <script>
        $(function(){
            /*var lis = document.getElementsByTagName("li");

            for(var i = 0; i < lis.length; i++){
                if(i % 2 === 0){
                    lis[i].style.backgroundColor = "hotpink";
                }else{
                    lis[i].style.backgroundColor = "yellow";
                }
            }*/


            var lis = $("li"); // jq对象
            for(var i = 0; i < lis.length; i++){
                if(i % 2 === 0){
                    // lis[i]: dom对象
                    lis[i].style.backgroundColor = "hotpink";
                }else{
                    // lis[i].style.backgroundColor = "yellow";
                    lis.get(i).style.backgroundColor = "yellow";
                }
            }
        })
    </script>

开关灯案例:

<script src="./jquery-1.12.4.js"></script>
    <script>
        $(function(){
            $("#btn1").click(function(){
                // 改变的是body的样式
                document.body.style.backgroundColor = "#fff";
            })


            $("#btn2").click(function(){
                // 改变的是body的样式
                // document.body.style.backgroundColor = "#000";

                // css() : 设置和获取元素的样式
                // css(name, value); name 是样式, value是样式值
                $("body").css("backgroundColor", "#000");
            })
        })
    </script>

2. 选择器

2.1 什么是jQuery选择器

jQuery选择器是jQuery为我们提供的一组方法,让我们更加方便的获取到页面中的元素。注意:jQuery选择器返回的是jQuery对象。

jQuery选择器有很多,基本兼容了CSS1到CSS3所有的选择器,并且jQuery还添加了很多更加复杂的选择器。【查看jQuery文档】

jQuery选择器虽然很多,但是选择器之间可以相互替代,就是说获取一个元素,你会有很多种方法获取到。所以我们平时真正能用到的只是少数的最常用的选择器。

2.2 css选择器

jQuery完全兼容css选择器

名称用法描述
ID选择器$(“#id”);获取指定ID的元素
类选择器$(“.class”);获取同一类class的元素
标签选择器$(“div”);获取同一类标签的所有元素
并集选择器$(“div,p,li”);使用逗号分隔,只要符合条件之一就可。
交集选择器$(“div.redClass”);获取class为redClass的div元素
子代选择器$(“ul>li”);使用>号,获取儿子层级的元素,注意,并不会获取孙子层级的元素
后代选择器$(“ul li”);使用空格,代表后代选择器,获取ul下的所有li元素,包括孙子等

跟CSS的选择器一模一样。

2.3 过滤选择器

这类选择器都带冒号:

名称用法描述
:eq(index)$(“li:eq(2)”).css(“color”, ”red”);获取到的li元素中,选择索引号为2的元素,索引号index从0开始。
:odd$(“li:odd”).css(“color”, ”red”);获取到的li元素中,选择索引号为奇数的元素
:even$(“li:even”).css(“color”, ”red”);获取到的li元素中,选择索引号为偶数的元素
:first$(“li:first”).css(“color”, ”red”);获取到的li元素中的第一个
:last$(“li:last”).css(“color”, ”red”);获取到的li元素中的最后一个

2.4 筛选选择器(方法)

筛选选择器的功能与过滤选择器有点类似,但是用法不一样,筛选选择器主要是方法。

名称用法描述
children(selector)$(“ul”).children(“li”)获取当前元素的所有子元素中的li元素
find(selector)$(“ul”).find(“li”);获取当前元素中的后代元素中的li元素
siblings(selector)$(“#first”).siblings(“li”);查找兄弟节点,不包括自己本身。
parent()$(“#first”).parent();查找父亲
eq(index)$(“li”).eq(2);相当于$(“li:eq(2)”),index从0开始
next()$(“li”).next()找下一个兄弟
prev()$(“li”).prev()找上一个兄弟

//【案例:下拉菜单】this+children+mouseenter+mouseleave
//【案例:突出展示】siblings+find
//【案例:手风琴】next+parent
//【案例:淘宝精品】index+eq

3. 其他补充

3.1 mouseover与mouseenter

mouseover和mouseoverenter都有鼠标经过的意思,但是在注册鼠标经过事件的时候,推荐使用mouseenter

mouseenter 与 mouseover 的不同

http://www.w3school.com.cn/tiy/t.asp?f=jquery_event_mouseenter_mouseover

  1. mouseover与mouseout是一对事件,当鼠标经过当前元素或者当前元素的子元素的时候,mouseover事件都会触发【事件冒泡】。

  2. mouseenter与mouseleave是一对事件,只有当鼠标经过当前元素时,事件会触发,鼠标经过子元素,mousenter事件是不会触发的。

3.2 index方法

index()方法返回的是当前元素在所有兄弟元素里面的索引。

<ul>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
  <li><a href="#">我是链接</a></li>
</ul>

当碰到这种结构的时候,推荐给li注册事件,这样通过index方法才能获取到正确的索引值。

3.3 区分jQuery与Javascript

JavaScript是一门编程语言,jQuery仅仅是用JavaScript实现的一个JavaScript库,目的是简化我们的开发。(联想记忆:不能扛着洗衣机去出差)

4. jQuery操作样式

4.1 css操作

功能:设置或者修改样式,操作的是style属性。

操作单个样式:

//name:需要设置的样式名称
//value:对应的样式值
css(name, value);
//使用案例
$("#one").css("background","gray");//将背景色修改为灰色

设置多个样式: 

//参数是一个对象,对象中包含了需要设置的样式名和样式值
css(obj);
//使用案例
$("#one").css({
    "background":"gray",
    "width":"400px",
    "height":"200px"
});

获取样式 :

//name:需要获取的样式名称
css(name);
//案例
$("div").css("background-color");

注意:获取样式操作只会返回第一个元素对应的样式值。

隐式迭代:

  1. 设置操作的时候,如果是多个元素,那么给所有的元素设置相同的值

  2. 获取操作的时候,如果是多个元素,那么只会返回第一个元素的值。

4.2 class操作

添加样式类 :

//name:需要添加的样式类名,注意参数不要带点.
addClass(name);
//例子,给所有的div添加one的样式。
$(“div”).addClass(“one”);

移除样式类 :

//name:需要移除的样式类名
removeClass(“name”);
//例子,移除div中one的样式类名
$(“div”).removeClass(“one”);

判断是否有某个样式类 :

//name:用于判断的样式类名,返回值为true false
hasClass(name)
//例子,判断第一个div是否有one的样式类
$(“div”).hasClass(“one”);

切换样式类 :

//name:需要切换的样式类名,如果有,移除该样式,如果没有,添加该样式。
toggleClass(name);
//例子
$(“div”).toggleClass(“one”);

【案例:tab栏切换案例.html】

5. jQuery操作属性

5.1 attr操作

设置单个属性

//第一个参数:需要设置的属性名
//第二个参数:对应的属性值
attr(name, value);
//用法举例
$(“img”).attr(“title”,”哎哟,不错哦”);
$(“img”).attr(“alt”,“哎哟,不错哦”);

设置多个属性

//参数是一个对象,包含了需要设置的属性名和属性值
attr(obj)
//用法举例
$("img").attr({
    title:"哎哟,不错哦",
    alt:"哎哟,不错哦",
    style:"opacity:.5"
});

获取属性

//传需要获取的属性名称,返回对应的属性值
attr(name)
//用法举例
var oTitle = $("img").attr("title");
alert(oTitle);

移除属性

//参数:需要移除的属性名,
removeAttr(name);
//用法举例
$("img").removeAttr("title");

【案例:美女相册.html】

5.2 prop操作

在jQuery1.6之后,对于checked、selected、disabled这类boolean类型的属性来说,不能用attr方法,只能用prop方法。

//设置属性
$(“:checked”).prop(“checked”,true);
//获取属性
$(“:checked”).prop(“checked”);//返回true或者false

【案例:表格全选案例.html】

// 标签上的自定义属性用attr方法
// 标签固有的属性用prop方法(src,title, checked, disabled, selected, width)
// 使用建议:attr方法使用的比较多,但是对于checked, disabled, selected只能使用prop方法

6. jQuery动画

jquery提供了三组基本动画,这些动画都是标准的、有规律的效果,jquery还提供了自定义动画的功能。【演示动画例子】

6.1 三组基本动画

显示(show)与隐藏(hide)是一组动画:

滑入(slideUp)与滑出(slideDown)与切换(slideToggle),效果与卷帘门类似

淡入(fadeIn)与淡出(fadeOut)与切换(fadeToggle)

show([speed], [callback]);
//speed(可选):动画的执行时间
//1.如果不传,就没有动画效果。如果是slide和fade系列,会默认为normal
//2.毫秒值(比如1000),动画在1000毫秒执行完成(推荐)
//3.固定字符串,slow(200)、normal(400)、fast(600),如果传其他字符串,则默认为normal。
//callback(可选):执行完动画后执行的回调函数
// show(speed, easing, callback)
// hide(speed, easing, callback)
// toggle(speed, easing, callback)
// 不传参,就没有动画效果
// 主要修改的时候元素的width、height、opacity
// 三个参数都是可选的
            
// 参数:
// speed: 动画时长,单位是ms,默认还提供了三个字符串的值,可选
//          "slow": 600
//          "normal": 400
//          "fast": 200
//          如果传递的是除了上面三个之外的字符串,取normal
// easing: 动画效果,默认值是swing(秋千,慢-快-慢),linear(匀速),可选
// callback: 动画结束的时候来执行的函数,可选
$("button").eq(0).click(function(){
                $("div").show(1000, function(){
                    console.log("show 动画结束了");
                });
 })

【案例:下拉菜单动画版.html】

【案例:京东轮播图(呼吸灯).html】

6.2 自定义动画

animate: 自定义动画

$(selector).animate({params},[speed],[easing],[callback]);
// {params}:要执行动画的CSS属性,带数字(必选)
// speed:执行动画时长(可选)
// easing:执行效果,默认为swing(缓动)  可以是linear(匀速)
// callback:动画执行完后立即执行的回调函数(可选)

6.3 动画队列与停止动画

在同一个元素上执行多个动画,那么对于这个动画来说,后面的动画会被放到动画队列中,等前面的动画执行完成了才会执行(联想:火车进站)。

//stop方法:停止动画效果
stop(clearQueue, jumpToEnd);
//第一个参数:是否清除队列
//第二个参数:是否跳转到最终效果
// 有默认值,两个都是false

【案例:手风琴特效】

【案例:音乐导航】

7. jQuery节点操作

7.1 创建节点

//$(htmlStr)
//htmlStr:html格式的字符串
$(“<span>这是一个span元素</span>”);

7.2 添加节点

//append  appendTo
//prepend prependTo
//before
//after
// append: 对appendChild() 的封装
// A.append(B);   把B元素添加到A元素里面去,作为最后一个子元素
// $("div").append( $(".outerP") );  // 页面上存在的元素,会是剪切的效果
// $("div").append( '<p class="outerP">这是div外的p元素</p>' ); // 参数可以是html字符串,先创建元素,在去添加
// appendTo
// B.appendTo(A);   把B元素添加到A元素里面去,作为最后一个子元素
// $(".outerP").appendTo( $("div") );
// $(".outerP").appendTo( "div" );  // 参数可以是选择器,先找到这个元素,在去将B添加到A
// prepend
// A.prepend(B);   把B元素添加到A元素里面去,作为第一个子元素
// $("div").prepend( $(".outerP") );
// $("div").prepend('<p class="outerP">这是div外的p元素</p>');
// prependTo()
// B.prependTo(A);  把B元素添加到A元素里面去,作为第一个子元素
// $(".outerP").prependTo( $("div") );
// $(".outerP").prependTo( "div" );
// after、before()
// after()
// A.after(B);    让B元素作为A的兄弟元素,并且放在A的后面
// $("div").after( $(".innerP") );

// before()
// A.before(B);   让B元素作为A的兄弟元素,并且放在A的前面

【案例:城市选择案例.html】

7.3 清空节点与删除节点

empty:清空指定节点的所有元素,自身保留(清理门户)

$(“div”).empty();//清空div的所有内容(推荐使用,会清除子元素上绑定的内容,源码)
$(“div”).html(“”);//使用html方法来清空元素,不推荐使用,会造成内存泄漏,绑定的事件不会被清除。

remove:相比于empty,自身也删除(自杀)

$(“div”).remove();

7.4 克隆节点

作用:复制匹配的元素

// 复制$(selector)所匹配到的元素(深度复制)
//cloneNode(true)
// 返回值为复制的新元素,和原来的元素没有任何关系了。即修改新元素,不会影响到原来的元素。
$(selector).clone();

【案例:微博发布】

【案例:弹幕效果】

8. jQuery特殊属性操作

8.1. val方法

val方法用于设置和获取表单元素的值,例如input、textarea的值

//设置值
$("#name").val(“张三”);
//获取值
$("#name").val();

【案例:京东搜索.html】

8.2. html方法与text方法

html方法相当于innerHTML text方法相当于innerText

//设置内容
$(“div”).html(“<span>这是一段内容</span>”);
//获取内容
$(“div”).html()

//设置内容
$(“div”).text(“<span>这是一段内容</span>”);
//获取内容
$(“div”).text()

区别:html方法会识别html标签,text方法会那内容直接当成字符串,并不会识别html标签。

8.3. width方法与height方法

设置或者获取高度

//带参数表示设置高度
$(“img”).height(200);
//不带参数获取高度
$(“img”).height();

获取网页的可视区宽高

//获取可视区宽度
$(window).width();
//获取可视区高度
$(window).height();
// width/height()  width
// 获取元素的宽高
// 设置:传参


 // innerWidth();   padding + width
    console.log($("div").innerWidth());

 // outerWidth();   border + padding + width
 // 可以传参,参数为true, 默认值是false
 console.log($("div").outerWidth());     

 // outerWidth(true);   margin + border + padding + width       
 console.log($("div").outerWidth(true));

8.4. scrollTop与scrollLeft

设置或者获取垂直滚动条的位置

//获取页面被卷曲的高度
$(window).scrollTop();
//获取页面被卷曲的宽度
$(window).scrollLeft();

【案例:仿腾讯固定菜单栏案例】 【案例:小火箭返航案例】

8.5. offset方法与position方法

offset方法获取元素距离document的位置,position方法获取的是元素距离有定位的父元素的位置。

//获取元素距离document的位置,返回值为对象:{left:100, top:100}
$(selector).offset();
//获取相对于其最近的有定位的父元素的位置。
$(selector).position();

9. jQuery事件机制

JavaScript中已经学习过了事件,但是jQuery对JavaScript事件进行了封装,增加并扩展了事件处理机制。jQuery不仅提供了更加优雅的事件处理语法,而且极大的增强了事件的处理能力。

9.1. jQuery事件发展历程(了解)

简单事件绑定>>bind事件绑定>>delegate事件绑定>>on事件绑定(推荐)

简单事件注册

click(handler)            单击事件
mouseenter(handler)        鼠标进入事件
mouseleave(handler)        鼠标离开事件

缺点:不能同时注册多个事件

bind方式注册事件

//第一个参数:事件类型
//第二个参数:事件处理程序
$("p").bind("click mouseenter", function(){
    //事件响应方法
});

缺点:不支持动态事件绑定

delegate注册委托事件

// 第一个参数:selector,要绑定事件的元素
// 第二个参数:事件类型
// 第三个参数:事件处理函数
$(".parentBox").delegate("p", "click", function(){
    //为 .parentBox下面的所有的p标签绑定事件
});

缺点:只能注册委托事件,因此注册时间需要记得方法太多了

on注册事件

9.2. on注册事件(重点)

jQuery1.7之后,jQuery用on统一了所有事件的处理方法。

最现代的方式,兼容zepto(移动端类似jQuery的一个库),强烈建议使用。

on注册简单事件

// 表示给$(selector)绑定事件,并且由自己触发,不支持动态绑定。
$(selector).on( "click", function() {});

on注册委托事件

// 表示给$(selector)绑定代理事件,当必须是它的内部元素span才能触发这个事件,支持动态绑定
$(selector).on( "click",“span”, function() {});

on注册事件的语法:

// 第一个参数:events,绑定事件的名称可以是由空格分隔的多个事件(标准事件或者自定义事件)
// 第二个参数:selector, 执行事件的后代元素(可选),如果没有后代元素,那么事件将有自己执行。
// 第三个参数:data,传递给处理函数的数据,事件触发的时候通过event.data来使用(不常使用)
// 第四个参数:handler,事件处理函数
$(selector).on(events[,selector][,data],handler);

9.3. 事件解绑

unbind方式(不用)

$(selector).unbind(); //解绑所有的事件
$(selector).unbind("click"); //解绑指定的事件

undelegate方式(不用)

$( selector ).undelegate(); //解绑所有的delegate事件
$( selector).undelegate( “click” ); //解绑所有的click事件

off方式(推荐)

// 解绑匹配元素的所有事件
$(selector).off();
// 解绑匹配元素的所有click事件
$(selector).off("click");

9.4. 触发事件

$(selector).click(); //触发 click事件
$(selector).trigger("click");

9.5. jQuery事件对象

jQuery事件对象其实就是js事件对象的一个封装,处理了兼容性。

//screenX和screenY    对应屏幕最左上角的值
//clientX和clientY    距离页面左上角的位置(忽视滚动条)
//pageX和pageY    距离页面最顶部的左上角的位置(会计算滚动条的距离)

//event.keyCode    按下的键盘代码
//event.data    存储绑定事件时传递的附加数据

//event.stopPropagation()    阻止事件冒泡行为
//event.preventDefault()    阻止浏览器默认行为
//return false:既能阻止事件冒泡,又能阻止浏览器默认行为。

【案例:钢琴版导航(加强).html】

10. jQuery补充知识点

10.1. 链式编程

通常情况下,只有设置操作才能把链式编程延续下去。因为获取操作的时候,会返回获取到的相应的值,无法返回 jQuery对象。

end(); // 筛选选择器会改变jQuery对象的DOM对象,想要回复到上一次的状态,并且返回匹配元素之前的状态。

【案例:五角星评分案例.html】

10.2. each方法

jQuery的隐式迭代会对所有的DOM对象设置相同的值,但是如果我们需要给每一个对象设置不同的值的时候,就需要自己进行迭代了。

作用:遍历jQuery对象集合,为每个匹配的元素执行一个函数

// 参数一表示当前元素在所有匹配元素中的索引号
// 参数二表示当前元素(DOM对象)
$(selector).each(function(index,element){});

【案例:不同的透明度.html】

10.3. 多库共存

jQuery使用$作为标示符,但是如果与其他框架中的$冲突时,jQuery可以释放$符的控制权.

var c = $.noConflict();//释放$的控制权,并且把$的能力给了c

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值