三天轻松搞定JQuery

简介: 三天轻松搞定JQuery

DAY01


1. 1 JQuery介绍


  • 概念: 一个JavaScript框架,简化JS开发。

JQuery是一个简洁而快速的JavaScript库,可用于简化事件处理,HTML文档遍历,Ajax交互和动画,以便快速开发网站。

目的是让开发者更容易地在网站上使用JavaScript。它不是一种单独的编程语言,与JavaScript一起工作。使用jQuery,将用更少的资源做更多的事情。

j 就是 JavaScript; Query 查询; 意思就是查询js,把js中的DOM操作做了封装,我们可以快速的查询使用里面的功能。


JavaScript框架:本质上就是一些js文件,封装了js的原生代码而已


1.2.JQuery 基础


1.2.1 jQuery 的下载

  1. jquery下载
  2. 导入JQuery的js文件(一般使用后缀为.min.js文件)

    在文档最末尾插入 script 标签,书写体验代码。

  1. 使用:

    入口函数:

 $(function () {   
    ...  // 此处是页面 DOM 加载完成的入口
}) ;


1.2.2. jQuery中的顶级对象$


  1. $是 jQuery 的别称,在代码中可以使用 jQuery 代替,但一般为了方便,通常都直接使用 $ 。
  2. $是jQuery的顶级对象,相当于原生JavaScript中的 window。把元素利用$包装成jQuery对象,就可以调用jQuery 的方法。


1.2.3. jQuery 对象和 DOM 对象


  1. 用原生 JS 获取来的对象就是 DOM 对象
  2. jQuery 方法获取的元素就是 jQuery 对象。
  3. jQuery 对象本质是: 利用$对DOM 对象包装后产生的对象(伪数组形式存储)。


/

// 1.DOM对象转换成jQuery对象,方法只有一种
var box = document.getElementById('box');  // 获取DOM对象
var jQueryObject = $(box);  // 把DOM对象转换为 jQuery 对象
// 2.jQuery 对象转换为 DOM 对象有两种方法:
//   2.1 jQuery对象[索引值]
var domObject1 = $('div')[0]
//   2.2 jQuery对象.get(索引值)
var domObject2 = $('div').get(0)


注意:

1. JQuery对象在操作时,更加方便。

2. JQuery对象和js对象方法不通用的.

3. 两者相互转换


jq – > js : jq对象[索引] 或者 jq对象.get(索引)

js – > jq : $(js对象)


1.3. jQuery 选择器


原生 JS 获取元素方式很多,很杂,而且兼容性情况不一致,因此 jQuery 给我们做了封装,使获取元素统一标准。


1.3.1. 基础选择器


$("选择器")   //  里面选择器直接写 CSS 选择器即可,但是要加引号

 

微信图片_20221009133414.png

1.3.2. 层级选择器


  • 后代选择器和子代选择器。

微信图片_20221009133516.png

<body>
   <div>我是div</div>
   <div class="nav">我是nav div</div>
   <p>我是p</p>
   <ul>
       <li>我是ul 的</li>
       <li>我是ul 的</li>        
       <li>我是ul 的</li>
   </ul>
   <script>
       $(function() {
           console.log($(".nav"));
           console.log($("ul li"));
       })
   </script>
</body>

1.3.3. 筛选选择器

微信图片_20221009133742.png

<body>
    <ul>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
    </ul>
    <ol>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
        <li>多个里面筛选几个</li>
    </ol>
    <script>
        $(function() {
            $("ul li:first").css("color", "red");
            $("ul li:eq(2)").css("color", "blue");
            $("ol li:odd").css("color", "skyblue");
            $("ol li:even").css("color", "pink");
        })
    </script>
</body>

1.3.4 知识铺垫


  • jQuery 设置样式

$('div').css('属性', '值')    

1

-jQuery 里面的排他思想



//

<body>
    <button>选择</button>
    <button>选择</button>
    <button>选择</button>
    <button>选择</button>
    <button>选择</button>
    <script>
        $(function() {
            $("button").click(function() {
                $(this).css("background", "pink");
                $(this).siblings("button").css("background", "");
            });
        });
    </script>
</body>


  • 隐式迭代
// 遍历内部 DOM 元素(伪数组形式存储)的过程就叫做隐式迭代。
// 简单理解:给匹配到的所有元素进行循环遍历,执行相应的方法,而不用我们再进行循环,简化我们的操作,方便我们调用。
$('div').hide();  // 页面中所有的div全部隐藏,不用循环操作


  • 链式编程
// 链式编程是为了节省代码量,看起来更优雅。
$(this).css('color', 'red').sibling().css('color', '');


1.4. jQuery 样式操作


  • jQuery中常用的样式操作有两种:css() 和 设置类样式方法


1.4.1. 方法1: 操作 css 方法


  • jQuery 可以使用 css 方法来修改简单元素样式; 也可以操作类,修改多个样式。


常用以下三种形式 :



/

// 1.参数只写属性名,则是返回属性值
var strColor = $(this).css('color');
// 2.  参数是属性名,属性值,逗号分隔,是设置一组样式,属性必须加引号,值如果是数字可以不用跟单位和引号
$(this).css(''color'', ''red'');
// 3.  参数可以是对象形式,方便设置多组样式。属性名和属性值用冒号隔开, 属性可以不用加引号
$(this).css({ "color":"white","font-size":"20px"});


1.4.2. 方法2: 设置类样式方法


作用等同于以前的 classList,可以操作类样式, 注意操作类里面的参数不要加点。


常用的三种设置类样式方法:


// 1.添加类
$("div").addClass("current");
// 2.删除类
$("div").removeClass("current");
// 3.切换类
$("div").toggleClass("current");


1.5. jQuery 效果


jQuery 给我们封装了很多动画效果,最为常见的如下:


  • 显示隐藏:show() / hide() / toggle() ;
  • 划入画出:slideDown() / slideUp() / slideToggle() ;
  • 淡入淡出:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;


1.5.1. 显示隐藏


显示隐藏动画,常见有三个方法:show() / hide() / toggle() ;


<body>
    <button>显示</button>
    <button>隐藏</button>
    <button>切换</button>
    <div></div>
    <script>
        $(function() {
            $("button").eq(0).click(function() {
                $("div").show(1000, function() {
                    alert(1);
                });
            })
            $("button").eq(1).click(function() {
                $("div").hide(1000, function() {
                    alert(1);
                });
            })
            $("button").eq(2).click(function() {
              $("div").toggle(1000);
            })
            // 一般情况下,我们都不加参数直接显示隐藏就可以了
        });
    </script>
</body>


1.5.2. 滑入滑出


滑入滑出动画,常见有三个方法:slideDown() / slideUp() / slideToggle() ;

代码演示


<body>
    <button>下拉滑动</button>
    <button>上拉滑动</button>
    <button>切换滑动</button>
    <div></div>
    <script>
        $(function() {
            $("button").eq(0).click(function() {
                // 下滑动 slideDown()
                $("div").slideDown();
            })
            $("button").eq(1).click(function() {
                // 上滑动 slideUp()
                $("div").slideUp(500);
            })
            $("button").eq(2).click(function() {
                // 滑动切换 slideToggle()
                $("div").slideToggle(500);
            });
        });
    </script>
</body>


1.5.3 淡入淡出


淡入淡出动画,常见有四个方法:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;

代码演示


<body>
    <button>淡入效果</button>
    <button>淡出效果</button>
    <button>淡入淡出切换</button>
    <button>修改透明度</button>
    <div></div>
    <script>
        $(function() {
            $("button").eq(0).click(function() {
                // 淡入 fadeIn()
                $("div").fadeIn(1000);
            })
            $("button").eq(1).click(function() {
                // 淡出 fadeOut()
                $("div").fadeOut(1000);
            })
            $("button").eq(2).click(function() {
                // 淡入淡出切换 fadeToggle()
                $("div").fadeToggle(1000);
            });
            $("button").eq(3).click(function() {
                //  修改透明度 fadeTo() 这个速度和透明度要必须写
                $("div").fadeTo(1000, 0.5);
            });
        });
    </script>
</body>


1.5.4 自定义动画


自定义动画非常强大,通过参数的传递可以模拟以上所有动画,方法为:animate() ;

代码演示

 

<body>
    <button>动起来</button>
    <div></div>
    <script>
        $(function() {
            $("button").click(function() {
                $("div").animate({
                    left: 500,
                    top: 300,
                    opacity: .4,
                    width: 500
                }, 500);
            })
        })
    </script>
</body>


1.5.5 停止动画排队


  • 动画或者效果一旦触发就会执行,如果多次触发,就造成多个动画或者效果排队执行。
  • 停止动画排队的方法为:stop() ;


  • stop() 方法用于停止动画或效果。


  • stop() 写到动画或者效果的前面, 相当于停止结束上一次的动画。


1.5.6. 事件切换


jQuery中为我们添加了一个新事件 hover() ; 功能类似 css 中的伪类 :hover 。

语法


hover([over,]out)     // 其中over和out为两个函数


  • over:鼠标移到元素上要触发的函数(相当于mouseenter)
  • out:鼠标移出元素要触发的函数(相当于mouseleave)
  • 如果只写一个函数,则鼠标经过和离开都会触发它


相关文章
|
JavaScript
jQuery toggleClass()
jQuery toggleClass()
51 0
|
1月前
|
Web App开发 JavaScript 前端开发
什么是jQuery
什么是jQuery
26 0
|
3月前
|
设计模式 JavaScript 前端开发
什么是Jquery?
什么是Jquery?
|
6月前
|
SQL JavaScript 前端开发
|
JavaScript 前端开发
jQuery 效果
jQuery 效果
114 0
|
前端开发 JavaScript 数据安全/隐私保护
html+js+Jquery(一)
html+js+Jquery(一)
219 0
html+js+Jquery(一)
|
Web App开发 JSON JavaScript
|
前端开发 JavaScript
|
JSON JavaScript 前端开发
|
前端开发 数据格式 JSON