Skip to content

jQuery

基础概念

JavaScript 库

JavaScript 库:即 library,是一个封装好的特定的集合(方法和函数)。从封装一大堆函数的角度理解库,就是在这个库中,封装了很多预先定义好的函数在里面,比如动画 animate、hide、show,比如获取元素等。

简单理解: 就是一个 JS 文件,里面对我们原生 js 代码进行了封装,存放到里面。这样我们可以快速高效的使用这些封装好的功能了。

jQuery,就是为了快速方便的操作 DOM,里面基本都是函数(方法)。

jQuery 的概念

jQuery 总体概况如下 :

  • jQuery 是一个快速、简洁的 JavaScript 库,其设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。
  • j 就是 JavaScript; Query 查询; 意思就是查询 js,把 js 中的 DOM 操作做了封装,我们可以快速的查询使用里面的功能。
  • jQuery 封装了 JavaScript 常用的功能代码,优化了 DOM 操作、事件处理、动画设计和 Ajax 交互。
  • 学习 jQuery 本质: 就是学习调用这些函数(方法)。
  • jQuery 出现的目的是加快前端人员的开发速度,我们可以非常方便的调用和使用它,从而提高开发效率。

jQuery概述

jQuery 的优点

  1. 轻量级。核心文件才几十 kb ,不会影响页面加载速度。
  2. 跨浏览器兼容,基本兼容了现在主流的浏览器。
  3. 链式编程、隐式迭代。
  4. 对事件、样式、动画支持,大大简化了 DOM 操作。
  5. 支持插件扩展开发。有着丰富的第三方的插件,例如:树形菜单、日期控件、轮播图等。
  6. 免费、开源。

基本使用

下载

jQuery 的官网地址: https://jquery.com/ ,官网即可下载最新版本。

版本介绍:

  • 1x :兼容 IE 678 等低版本浏览器, 官网不再更新
  • 2x :不兼容 IE 678 等低版本浏览器, 官网不再更新
  • 3x :不兼容 IE 678 等低版本浏览器, 是官方主要更新维护的版本

使用步骤:

  1. 引入 jQuery 文件。
  2. 在文档最末尾插入 script 标签,书写体验代码。
  3. $('div').hide() 可以隐藏盒子。

示例代码

html
<!doctype html>
<html lang="zh-CN">
  <head>
    <meta charset="UTF-8" />
    <title>Title</title>
    <script src="jquery.min.js"></script>
    <style>
      div {
        width: 200px;
        height: 200px;
        background-color: pink;
      }
    </style>
  </head>
  <body>
    <div></div>
  </body>
  <script>
    /*点击之后影藏盒子*/
    // 原生 JavaScript
    var div = document.querySelector("div");
    div.onclick = function () {
      div.style.display = "none";
    };

    // jquery
    $("div").click(function () {
      $(this).hide();
    });
  </script>
</html>

jQuery 的入口函数

jQuery 中常见的两种入口函数:

javascript
// 第一种: 简单易用。
$(function () {
  //...
  // 此处是页面 DOM 加载完成的入口
});

// 第二种: 繁琐,但是也可以实现
$(document).ready(function () {
  //...
  //  此处是页面DOM加载完成的入口
});

总结:

  1. 等着 DOM 结构渲染完毕即可执行内部代码,不必等到所有外部资源加载完成,jQuery 帮我们完成了封装。
  2. 相当于原生 js 中的 DOMContentLoaded。
  3. 不同于原生 js 中的 load 事件是等页面文档、外部的 js 文件、css 文件、图片加载完毕才执行内部代码。
  4. 更推荐使用第一种方式。

jQuery 顶级对象

$ 是 jQuery 的别称,在代码中可以使用 jQuery 代替,但一般为了方便,通常都直接使用 $

$ 是 jQuery 的顶级对象,相当于原生 JavaScript 中的 window 。把元素利用 $ 包装成 jQuery 对象,就可以调用 jQuery 的方法。

html
<script>
    // 1. $ 是 jQuery 的别称(另外的名字)
    // $(function() {
    //     $('div').hide();
    // });

    jQuery(function () {
        jQuery('div').hide();
    });
    // 2. $ 同时也是 jQuery 的 顶级对象
</script>

jQuery 对象和 DOM 对象

使用 jQuery 方法和原生 JS 获取的元素是不一样的,总结如下 :

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

注意:

只有 jQuery 对象才能使用 jQuery 方法,DOM 对象则使用原生的 JavaScript 方法。

jQuery对象和DOM对象

jQuery 对象和 DOM 对象转换

DOM 对象与 jQuery 对象之间是可以相互转换的。因为原生 js 比 jQuery 更大,原生的一些属性和方法 jQuery 没有给我们封装. 要想使用这些属性和方法需要把 jQuery 对象转换为 DOM 对象才能使用。

html
<script>
  // 1. DOM 对象:  用原生js获取过来的对象就是DOM对象
  var myDiv = document.querySelector("div");
  console.dir(myDiv);

  // 2. jQuery 对象: 用 jquery 方式获取过来的对象是 jQuery 对象。 本质:通过 $ 把 DOM 元素进行了包装
  $("div"); // $('div') 是一个 jQuery 对象
  console.dir($("div"));

  // 3. jQuery 对象只能使用 jQuery 方法,
  // DOM 对象则使用原生的 JavaScirpt 属性和方法
  // myDiv.style.display = 'none';
  // myDiv.hide(); // myDiv是一个dom对象不能使用 jquery 里面的 hide方法
  $("div").style.display = "none"; //这个 $('div')是一个 jQuery 对象不能使用原生 js 的属性和方法

  /*04 DOM对象与jquery对象相互转化*/
  let my_div = document.querySelector("div");

  my_div.onclick = function () {
    // DOM 对象转换 直接修改属性
    // my_video.style.display = 'none'

    // 2. jQuery 对象转换为 DOM 对象
    // $('div')[0].style.display= 'none'
    $("div").get(0).style.display = "none";
  };
</script>

总结:实际开发比较常用的是把 DOM 对象转换为 jQuery 对象,这样能够调用功能更加强大的 jQuery 中的方法。