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 的优点
- 轻量级。核心文件才几十 kb ,不会影响页面加载速度。
- 跨浏览器兼容,基本兼容了现在主流的浏览器。
- 链式编程、隐式迭代。
- 对事件、样式、动画支持,大大简化了 DOM 操作。
- 支持插件扩展开发。有着丰富的第三方的插件,例如:树形菜单、日期控件、轮播图等。
- 免费、开源。
基本使用
下载
jQuery 的官网地址: https://jquery.com/ ,官网即可下载最新版本。
版本介绍:
- 1x :兼容 IE 678 等低版本浏览器, 官网不再更新
- 2x :不兼容 IE 678 等低版本浏览器, 官网不再更新
- 3x :不兼容 IE 678 等低版本浏览器, 是官方主要更新维护的版本
使用步骤:
- 引入
jQuery
文件。 - 在文档最末尾插入
script
标签,书写体验代码。 $('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加载完成的入口
});
总结:
- 等着 DOM 结构渲染完毕即可执行内部代码,不必等到所有外部资源加载完成,jQuery 帮我们完成了封装。
- 相当于原生 js 中的 DOMContentLoaded。
- 不同于原生 js 中的 load 事件是等页面文档、外部的 js 文件、css 文件、图片加载完毕才执行内部代码。
- 更推荐使用第一种方式。
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 获取的元素是不一样的,总结如下 :
- 用原生 JS 获取来的对象就是 DOM 对象
- jQuery 方法获取的元素就是 jQuery 对象。
- jQuery 对象本质是: 利用 $ 对 DOM 对象包装后产生的对象(伪数组形式存储)。
注意:
只有 jQuery 对象才能使用 jQuery 方法,DOM 对象则使用原生的 JavaScript 方法。
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 中的方法。