jQuery只是一个jquery-xxx.js文件,可以从jQuery官网下载最新版本。
使用,引入jQuery文件即可:
data:image/s3,"s3://crabby-images/38aed/38aed5d882bd1d6c02156124ea4ae2d9c3e53951" alt=""
选择器
基本选择器
-
按id查找,id前需要添加:#
image.png
-
按tag查找
按tag查找,只需要写上tag名称就可以了
image.png
-
按class查找,class前需要添加:.
image.png
如果有多个class,可以查找同时包含多个class的节点
image.png
-
按属性查找,属性用中括号括起来
当属性的值包含空格等特殊字符时,需要用双引号括起来
image.png
还可以使用前缀查找或者后缀查找
image.png
image.png
-
组合查找
image.png
image.png
多项选择器
多项选择器就是把多个选择器用逗号组合起来一起用
data:image/s3,"s3://crabby-images/f1f27/f1f2721b83a9dfc1ea67f744391c413d210ee4c5" alt=""
层级选择器
如果两个DOM元素具有丛集关系,可以用$('ancestor descendant')来选择,层级之间用空格隔开。
例如:
data:image/s3,"s3://crabby-images/ce494/ce494ba8e493ea399206ee368a3e8a91d9a24ec2" alt=""
要选出JavaScript:
data:image/s3,"s3://crabby-images/136d2/136d24fb0e48442551202552b6b551f4d9eedcf3" alt=""
层级选择器相比单个选择器好处在于,缩小了选择范围。
过滤器(Filter)
过滤器一般不单独使用,它通常附加在选择器上,帮助更精确地定位元素。
data:image/s3,"s3://crabby-images/9a7a5/9a7a50727c03b310cc6743ea6684bdd46d4805d6" alt=""
表单相关
针对表单元素,jQquery还有一组特殊的选择器
- :input,可以选择<input>,<textarea>,<select>,<button>
- :file,可以选择<input type='file'>,和input[type=file]一样
- :checkbox,可以选择复选框,和input[type=checkbox]一样
- :radio,可以选择单选框,和input[type=radio]一样
- :focus,可以选择当前输入焦点的元素,例如把光标放到一个<input>上,用$('input:focus')就可以选出
- :checked,选择当前勾上的单选框或复选框,用这个可以立即获取用户选择的项目,如$('input[type=radio]:checked')
- :enabled,可以选择可以争取正常输入的<input>、<select>等,也就是没有灰掉的输入
- :disabled,和:enabled相反,选择不能输入的
- :visible,选择可见的
-
:hidden,选择隐藏的
image.png
查找
通常情况下选择器可以直接定位到我们想要的元素,但是,当我们拿到一个jQuery对象后,还可以以这个对象为基准,进行查找和过滤。最常见的查找是在某个节点的所有子节点中查找,使用find()方法,它本身又接收一个任意的选择器。
如:
data:image/s3,"s3://crabby-images/e5f82/e5f82c12410b84dcb34e48897ea0e91acdbcb831" alt=""
用find()查找:
data:image/s3,"s3://crabby-images/73a46/73a469bd7a3453b14054b8a6896b76510a4abfee" alt=""
如果要从当前节点开始向上查找,使用parent()方法:
data:image/s3,"s3://crabby-images/b2ce3/b2ce30da3c421a55a4ea240ab8122abab532a99c" alt=""
对于同一层级节点,可以通过next()和prev()方法:
data:image/s3,"s3://crabby-images/1cc09/1cc095625a2e72e5773d2fb34600240551c5c74f" alt=""
过滤
和函数式编程中的map、fileter类似,jQuery对象也有类似的方法
filter()可以过滤掉不符合选择器条件的节点:
data:image/s3,"s3://crabby-images/3cca1/3cca155af34085fe25fd84d35e49deb1f11ed9af" alt=""
或者传入一个函数,要特别注意函数内部的this被绑定为DOM对象,不是jQuery对象:
data:image/s3,"s3://crabby-images/cc440/cc4403871ace53eee5723f9fd6f3e9901ddb8788" alt=""
map()方法把一个jQuery对象包含的若干DOM节点转化为其他对象:
data:image/s3,"s3://crabby-images/c423b/c423b1f09d0277b4cf27385f0b07bbce271e2d1b" alt=""
如果,一个jQuery对象不只包含了一个DOM节点,first()、last()和slice()方法可以返回一个新的jQuery对象,把不需要的DOM节点去掉:
data:image/s3,"s3://crabby-images/8793b/8793b185cf60bb2ca12dabf4a7136d8b18ca97a2" alt=""
操作DOM
修改text和html
jQuery对象的text()和html()方法分别获取节点的文本和原始html文本
如:
data:image/s3,"s3://crabby-images/74307/74307a8962b9381961accc8f386559babc7db808" alt=""
分别获取文本和html:
data:image/s3,"s3://crabby-images/da81c/da81c9f52cac22bc0a7406d9b8172075392720af" alt=""
设置文本或html,无参数调用是获取,传入参数就是设置:
data:image/s3,"s3://crabby-images/72517/7251719048db92f5a9fdad1be5b00f9f562c2274" alt=""
修改css
如:
data:image/s3,"s3://crabby-images/def8d/def8db2f0c8fab1c6ce53faf963c28a970c4689e" alt=""
要高亮显示动态语言,调用jQuery对象的 css('name', 'value') 方法:
data:image/s3,"s3://crabby-images/f5e5a/f5e5aabd6ab5c40f19c959d73fb2e09361622cf2" alt=""
jQuery对象的 css() 方法可以这么用:
data:image/s3,"s3://crabby-images/b7d13/b7d1322f5240e4edc29043bc0f969a4dde5454a1" alt=""
css()方法作用于DOM节点的style属性,具有最高优先级。如果要修改class属性:
data:image/s3,"s3://crabby-images/3bdcd/3bdcd5db2f9a18199ed839f82e16fb8cdf691212" alt=""
attr()和removeAttr()方法用于操作DOM节点的属性:
data:image/s3,"s3://crabby-images/caab5/caab5c18c4a56cbbd9eb4156dd5547ca5f3e7453" alt=""
prop() 方法和 attr() 类似,对于属性checked处理有所不同:
data:image/s3,"s3://crabby-images/0912b/0912b1bbacd4fb016c02ff121adbcf526d761d1b" alt=""
prop()返回值更合理一些,不过,is()方法判断更好:
data:image/s3,"s3://crabby-images/0de27/0de278a2ff5a780b76fc67d90ba86ebfa4cefb15" alt=""
类似的属性还有selected,处理时最好用is(':selected')
显示和隐藏DOM
jQuery提供show()和hide()方法:
data:image/s3,"s3://crabby-images/4df1a/4df1a9ee4642bf837f1dbd0f4a098460e8a9e41f" alt=""
获取DOM信息
data:image/s3,"s3://crabby-images/522f8/522f8a077275ce319bbdb517746c9c58e7036e40" alt=""
操作表单
对于表单,jQuery对象统一提供val()方法获取和设置对应的value属性:
data:image/s3,"s3://crabby-images/a1f9f/a1f9f114bf95b1f8a163be7315e299ea1483e5f1" alt=""
修改html 结构
-
添加DOM
append()方法,把DOM添加到最后
如:
image.png
列表新增项,首先要拿到<ul>节点,然后调用append()传入html片段:
image.png
image.png
除接受字符串外,append()对象还可以传入原始的DOM对象、jQuery对象和函数对象:
image.png
propend(),把DOM添加到最前
同级节点,可以用after()或者before()
-
删除DOM
拿到jQuery对象后直接调用remove()方法就可以了,如果jQuery包含若干DOM节点,实际上而已一次删除多个节点。
image.png
网友评论