网站首页 > 技术文章 正文
1.jQuery的三种$
1)$可以是$(expresion),即css选择器、Xpath或html元素,也就是通过上述表达式来匹配目标元素。
比如:$("a")构造的这个对象,是用CSS选择器构建了一个jQuery对象--它选择了所有的<a/>这个标签。
eg:$("a").click(function{...}) :就是在点击页面上的任何一个链接时的触发事件。
alert($("div>p").html):表示弹出div下的一级节点标签为p的内容
$("<div><p>Hello</p></div>").appendTo("body"):表示$中的是一个字符串,用这样一段字串构建了jQuery对象,然后向<body/>中添加这一字串。
2)$可以是$(element),即一个特定的DOM元素。如常用的DOM对象有document、location、form等。
eg:$(document).find("div>p").html):表示$中的document是一个DOM元素,即在全文寻找带<p>的<div>元素,并显示<p>中的内容。
3)$可以是$(function),即一个函数,它是$(document).ready的一个速记方式。
eg:
$(document).ready(function{
alert("Hello world!");
}) //意思是当文档载入完毕就执行
可简化为:
$(function{
alert("Hello world!");
});
2.对于选择HTML文档中的elements,jQuery有两种方法:
1)如$("div>ul a"),它的意思是div标签中的ul标签中的a标签
不过,$('div>ul')和$('div ul')是有区别的,
$('div>ul')是<div>的直接后代里找<ul>; 而$('div ul')是在<div>的所有后代里找<ul>。
2)用jQuery对象的几个方法(如方法find()、each()等) $("#orderedlist).find("li") 就像 $("#orderedlist li"). each一样迭代了所有的li,而表达式中的“#”表示HTML中的ID,如上例中的“#orderedlist”就表示“ID为orderedlist所在的标签”。
3.标签选择器$('p')、类选择器$('.myClass')、id选择器$('#myId')
4.$('#sId li:not(.horizontal)'),就是指类名"sId"里面的所有li的子孙中没有horizontal类的所有元素。
5.XPath选择器
eg:选择所有带有title 属性的链接,我们会这样写:$('a[@title]') ,下面是解析:
里带@,说明里的是元素的属性;是个属性选择器
里没@,说明里的是元素的子孙
1)$('ul li')和$('ul[li]')虽然返回的都是一个jQuery数组,但两者的含义正好相反。前者是要找<ul>下所有<li>子孙,而后者却是在找所有子孙为<li>的<ul>数组。
2)在XPath中,要找一个“以...开头”的属性,用^=,如找一个name属性是以mail开头的input元素,就用 $('input[@name^="mail"]')
要找一个“以...结尾”的属性,要用$=
要找一个“不头不尾”的属性,用*=
6.不属于上述的CSS和XPath的选择器,就是自定义的选择器了,用“:”表示,这里要用的就是:first,:last,:parent ,:hidden,:visible,:odd,:even,:not('xxx'), ":eq(0)"(始于0),:nth(n),:gt(0),:lt(0),:contains("xxx") 如:$('tr:not([th]):even')意为<tr>元素的子孙中不含<th>的所有子孙的偶数项
7.其他的如下:
$('th').parent—— th标签的父节点
$('td:contains("Henry")').prev——内容包含有"Henry"的<td>的上一个节点
$('td:contains("Henry")').next——内容包含有"Henry"的<td>的下一个节点
$('td:contains("Henry")').siblings——内容包含有"Henry"的<td>的所有兄弟节点
还有一个,就是end,这个方法肯定是用在某个DOM节点执行了某一动作之后,还想在与其相关的节点上执行类似动作,这里就要用到end。用过end方法之后,所返回的是执行动作的那个节点的父节点上。举个例子
$(...).parent.find(...).addClass.end 这里执行动作的节点是find(...),是一个数组对象,它所做的动作是“addClass”,之后,用了个end,这时所返回的东东就是指向了parent所指向的节点,也就是执行“addClass”动作的那个数组对象的父节点。
8.要直接访问DOM元素,可用get(0)的方法,如 $('#myelement').get(0),也可缩写成$('#myelement')[0]
猜你喜欢
- 2024-10-07 手把手的教你用PHP将HTML生成PDF(php生成图片 html转img)
- 2024-10-07 你真的熟悉 HTML 标签吗?(html基本标签大全)
- 2024-10-07 PHP获取指定网页的HTML代码并执行输出
- 2024-10-07 一个命令,让你的网站支持https(cad组合成一个整体快捷键命令)
- 2024-10-07 html常用代码大全(html代码总结)
- 2024-10-07 前端入门新人必看:html和css的使用方法以及样式
- 2024-10-07 谁说网页上的文本无法复制?电脑大神教你3招,学到就是赚到!
- 2024-10-07 如何向Vue项目添加JavaScript库所需的代码
- 2024-10-07 Nginx设置404页面(nginx 403页面)
- 2024-10-07 HTML常用全部代码,你懂,你不想成功都难
- 1518℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 599℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 521℃MySQL service启动脚本浅析(r12笔记第59天)
- 489℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 489℃启用MySQL查询缓存(mysql8.0查询缓存)
- 477℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 456℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 454℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)