当前位置:首页 > 技术分析 > 正文内容

jQuery学习-----(一)JQuery的'$'符号用法

ruisui8815小时前技术分析2

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]

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/4657.html

标签: jq添加元素
分享给朋友:

“jQuery学习-----(一)JQuery的&#39;$&#39;符号用法” 的相关文章

Windows 下 Git 拉 Gitlab 代码

读者提问:『阿常你好,Windows 下 Git 拉 Gitlab 代码的操作步骤可以分享一下吗?』阿常回答:好的,总共分为五个步骤。一、Windows 下安装 Git官网下载链接:https://git-scm.com/download/winStandalone Installer(安装版)注意...

内存问题探微

这篇文章是我在公司 TechDay 上分享的内容的文字实录版,本来不想写这么一篇冗长的文章,因为有不少的同学问是否能写一篇相关的文字版,本来没有的也就有了。说起来这是我第二次在 TechDay 上做的分享,四年前第一届 TechDay 不知天高地厚,上去讲了一个《MySQL 最佳实践》,现在想起来那...

js中数组filter方法的使用和实现

定义filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。语法var newArray = arr.filter(callback(element[, index[, selfArr]])[, thisArg])参数callback循环数组每个元素时调用的回调函数。回调函...

Vue2的16种传参通信方式

前言先直入主题列出有哪些传参方式,下面再通过事例一一讲解。props(父传子)$emit与v-on (子传父)EventBus (兄弟传参).sync与update: (父子双向)v-model (父子双向)ref$children与$parent$attrs与$listeners (爷孙双向)pr...

vue2中路由的使用步骤,你学会了吗?

今天我们来整理下关于vue2中路由的使用步骤:1. 导入 vue 文件和Vue-router文件(注意:vue-router是依赖vue运行的,所以一定在vue后引入vue-router)2. 定义路由组件模板3. 创建路由实例并定义路由规则4. 将路由实例挂载给Vue实例5. 在结构区域定义控制路...

VUE 技术栈

官网链接:https://cn.vuejs.org/什么是vue:渐进式JavaScript 框架vue-cli链接:https://cli.vuejs.org/vue-cli安装:npm install -g @vue/clivue -V创建一个项目:vue create xxxxxx模版语法:文...