2021-12-5

JavaScript之JQuery
1.JQueryde 功能
1.消除浏览器差异:不需要自己写冗长的代码来针对不同的浏览器来绑定事件,编写AJAX等代码;
2.简洁的操作DOM的方法:写$(’#test’)肯定比document.getElementById(‘test’)来得简洁;
3.轻松实现动画、修改CSS等各种操作
2.Jquery的引用

<html>
<head>
    <script src="//code.jquery.com/jquery-1.11.3.min.js"></script>
	...
</head>
<body>
    ...
</body>
</html>

3.JQuery
3.1. 符 号 是 j Q u e r y 的 别 名 , j Q u e r y 把 所 有 功 能 全 部 封 装 在 一 个 全 局 变 量 j Q u e r y 中 , 而 符号是jQuery的别名,jQuery把所有功能全部封装在一个全局变量jQuery中,而 jQueryjQueryjQuery也是一个合法的变量名。本质上是一个函数。
3.2 如果$符号被占用

$; // jQuery(selector, context)
jQuery.noConflict();
$; // undefined
jQuery; // jQuery(selector, context)

原理如下:jQuery在占用$之前,先在内部保存了原来的 $,调用jQuery.noConflict()时会把原来保存的变量还原。
3.3 选择器
3.3.1 按照ID查找

// 查找<div id="abc">:
var div = $('#abc');

返回的为jQuery对象,不存在返回为[],不会返回undefine和null
JQuery和DOM对象可以相互转化

var div = $('#abc'); // jQuery对象
var divDom = div.get(0); // 假设存在div,获取第1个DOM元素
var another = $(divDom); // 重新把DOM包装为jQuery对象

3.3.2按照tag查找

var ps = $('p'); // 返回所有<p>节点
ps.length; // 数一数页面有多少个<p>节点

按照tag查找写上tag名称即可
3.3.3按照class查找
在class名称前面需要加点

var a = $('.red'); // 所有节点包含`class="red"`都将返回
// 例如:
// <div class="red">...</div>
// <p class="green red">...</p>

通常很多节点有多个class,我们可以查找同时包含red和green的节点:

var a = $('.red.green'); // 注意没有空格!
// 符合条件的节点:
// <div class="red green">...</div>
// <div class="blue green red">...</div>

3.3.4按照属性查找
以表单中按照属性查找为例:

var email = $('[name=email]');

当属性的值包含空格等特殊字符时,需要用双引号括起来。

var passwordInput = $('[type=password]');

按属性查找还可以使用前缀查找或者后缀查找:

var icons = $('[name^=icon]'); // 找出所有name属性值以icon开头的DOM
// 例如: name="icon-1", name="icon-2"
var names = $('[name$=with]'); // 找出所有name属性值以with结尾的DOM
// 例如: name="startswith", name="endswith"

找出属性名称中,至少有一个以icon为开头的

var icons = $('[class^="icon-"]'); // 找出所有class包含至少一个以`icon-`开头的DOM
// 例如: class="icon-clock", class="abc icon-home"

3.3.5组合查找
组合查找就是把上述简单选择器组合起来使用。如果我们查找$(’[name=email]’),很可能把表单外的

也找出来,但我们只希望查找,就可以这么写:

var emailInput = $('input[name=email]'); // 不会找出<div name="email">
同样的,根据tag和class来组合查找也很常见:

var tr = $('tr.red'); // 找出<tr class="red ...">...</tr>

(待补充)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值