jQuery 基础

1.基本使用

  • 简介:jQuery 是一个高效、精简并且功能丰富的 JavaScript 工具库。它提供的 API 易于使用且兼容众多浏览器,这让诸如 HTML 文档遍历和操作、事件处理、动画和 Ajax 操作更加简单
  • 引入jquery
<script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
  • 入口函数:jQuery默认可以使用 $ / jQuery / window.$ / window.jQuery 来调用,而且他是一个函数对象
<script>
    $(function(){
        console.log("开始使用jQuery - 1")
    })
    jQuery(function(){
        console.log("开始使用jQuery - 2")
    })
    window.$(function(){
        console.log("开始使用jQuery - 3")
    })
    window.jQuery(function(){
        console.log("开始使用jQuery - 4")
    })
</script>
  • Query入口函数执行时机比window.onload早,window.onload必须等到页面内包括图片的所有元素加载完毕后才能执行,而Query入口函数是DOM结构绘制完毕后就执行(DOMContentLoaded事件)
<script>
    //起始时间
    var start = new Date().getTime() 
    //监听整个页面加载
    window.onload = function(){
        console.log('页面加载完成,用时(毫秒) = ',new Date().getTime() - start)
    }
    //监听DOMContentLoaded 事件
    document.addEventListener('DOMContentLoaded', function (event) {
        console.log('DOMContentLoaded完成,用时(毫秒) = ',new Date().getTime() - start)
    })
    //jquery
    $(function(){
        console.log('jquery ready,用时(毫秒) = ',new Date().getTime() - start)
    })
</script>

2.jquery对象与原生dom

  • jquery对象是原生dom的包装集
<script>
    $(function(){
        var $box = $(".box")
        console.log($box)
    })
</script>

  • 可以通过下标或者get()方法来提取jquery对象中的原生dom元素
<script>
    $(function(){
        var $box = $(".box")
        // 通过下标提取dom元素
        $box[0].innerHTML = "hello world"
        $box[1].innerHTML = "星期五"
        // 通过get()方法提取dom元素
        $box.get(0).style.color = "red"
        $box.get(1).style.color = "blue"
    })
</script>

3.相关特性

  • 链式编程:jQuey支持链式编程,因为jQuery的函数方法会return一个自身的jQuery对象,而这个对象又可以接着调用jquery的方法,以此类推,这就是链式编程的原理。
<script>
    $(function(){
        var $box = $(".box")
        $box.eq(0).html("链式编程").css("font-size","30px").attr("id","test")
    })
</script>

  • 隐式迭代:原生js一次只能操作一个Dom,而jQuery可同时多操多个jq对象(自动遍历)
<body>
    <p>床前明月光</p>
    <p>疑是地上雪</p>
</body>
<script>
    $(function(){
        var $p = $("p")
        $p.css({
            color:"green",
            "font-size":"30px"
        })
    })
</script>

4.多库共存

  • 查看jQuery的版本:直接查看文件名或者源码,或者直接打印当前版本号
<script>
    //直接查看文件名,例如:jquery-1.12.4.js

    //打印当前版本号
    console.log($.fn.jquery) //1.12.4
</script
  • 多库共存的问题:如果同时引入多个版本的jQuery,因为所有的版本都使用相同的变量名$来调用JQuery,所以导致后面引入的覆盖前面,例如:
<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>Test</title>
    <!-- 引入1.12.4 -->
    <script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
    <!-- 引入3.4.1 -->
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
</head>

<body>>
</body>
<script>
    console.log($.fn.jquery) //3.4.1

    //说明最后生效的是3.4.1
</script>
</html>
  • 解决办法:可以让后面的版本使用其他的字符来代替$,从而达到多库共存的目的,这个方法就是 noConflict(),为当前版本使用其他字符来代替$
<script>
    //当前版本释放$符号,并用_$来代替
    var _$ = $.noConflict()
    // $代表1.12.4版本
    console.log($.fn.jquery) //1.12.4
    // _$代表3.4.1版本
    console.log(_$.fn.jquery) //3.4.1
</script>
</html>
posted @ 2019-10-04 15:19  ---空白---  阅读(279)  评论(0编辑  收藏  举报