JQuery入门篇

jQuery选择器

“$”表示JQuery对象

根据ID查找

$(‘#var’)表示将一个id值为var的DOM节点封装成一个jQuery对象,DOM节点必须以“#”开头。

例如:有<div id="var "></div>存在,使用$(‘#var’)之后会将其封装成[<div id="var "></div>],但是如果不存在id=”var”,返回的jQuery对象是[],而不是一个null或undefined。

// 查找<div id="abc">:

var div = $('#abc');           //获取id=”abc”的节点

根据class查找

1、只存在一个class样式:

var a = $('.red'); // 所有节点包含`class="red"`都将返回

// 例如:

// <div class="red">...</div>

// <p class="green red">...</p>

根据Tag(标签)查找

var ps = $('p'); // 返回所有<p>节点

ps.length; // 数一数页面有多少个<p>节点

根据属性查找

var email = $('[name=email]'); // 找出<??? name="email">

var passwordInput = $('[type=password]'); // 找出<??? type="password">

//当属性值包含空格等特殊字符时,需要加上“”

var a = $('[items="A B"]'); // 找出<??? items="A B">

使用前缀、后缀的属性查找

var icons = $('[name^=icon]'); // 找出所有name属性值以icon开头的DOM

// 例如: name="icon-1", name="icon-2"

var names = $('[name$=with]'); // 找出所有name属性值以with结尾的DOM

// 例如: name="startswith", name="endswith"

组合查找

var emailInput = $('input[name=email]'); // 只查找input标签里name属性为Email的DOM节点,不会找出<div name="email">

多项选择器查找

$('p,div'); // 把<p>和<div>都选出来

$('p.red,p.green'); // 把<p class="red">和<p class="green">都选出来

要注意的是,选出来的元素是按照它们在HTML中出现的顺序排列的,而且不会有重复元素。例如,<p class="red green">不会被上面的$('p.red,p.green')选择两次。

层级选择器

对于两个DOM元素具有层级关系,可以使用层级选择器。层级选择器之间使用空格。

$('form[name=upload] input’);            //选择form表单中name属性为upload的表单内容

$('form.test p input');                   // 在form表单选择被<p>包含的<input>的节点

子选择器

子选择器跟层级选择器很类似,区别在于子选择器限定的层级关系必须是父子节点。

<!-- HTML结构 -->

<div class="testing">

<ul class="lang">

<li class="lang-javascript">JavaScript</li>

<li class="lang-python">Python</li>

<li class="lang-lua">Lua</li>

</ul>

</div>

$('ul.lang>li.lang-javascript'); // 可以选出[<li class="lang-javascript">JavaScript</li>]

$('div.testing>li.lang-javascript'); // [], 无法选出,因为<div>和<li>不构成父子关系

过滤器

过滤器通常结合选择器一起使用

$('ul.lang li'); // 选出JavaScript、Python和Lua 3个节点

$('ul.lang li:first-child'); // 仅选出JavaScript

$('ul.lang li:last-child'); // 仅选出Lua

$('ul.lang li:nth-child(2)'); // 选出第N个元素,N从1开始

$('ul.lang li:nth-child(even)'); // 选出序号为偶数的元素

$('ul.lang li:nth-child(odd)'); // 选出序号为奇数的元素

查找

通常在某个节点的子节点中查找。使用find()方法,可以接受任何一个选择器。

例如:

<!-- HTML结构 -->

<ul class="lang">

<li class="js dy">JavaScript</li>

<li class="dy">Python</li>

<li id="swift">Swift</li>

<li class="dy">Scheme</li>

<li name="haskell">Haskell</li>

</ul>

1、向下查找:

var ul = $('ul.lang'); // 获得<ul>

var dy = ul.find('.dy'); // 获得JavaScript, Python, Scheme

var swf = ul.find('#swift'); // 获得Swift

var hsk = ul.find('[name=haskell]'); // 获得Haskell

2、向上查找,使用parent()方法:

var swf = $('#swift'); // 获得Swift

var parent = swf.parent(); // 获得Swift的上层节点<ul>

var a = swf.parent('.red'); // 获得Swift的上层节点<ul>,同时传入过滤条件。如果ul不符合条件,返回空jQuery对象

3、同层级的查找,使用prev()和next()方法

var swift = $('#swift');

swift.next(); // Scheme

// 返回空的jQuery对象,因为Swift的下一个元素为Scheme不符合条件[name=haskell]

swift.next('[name=haskell]');

swift.prev(); // Python

swift.prev('.dy'); // Python,因为Python同时符合过滤器条件.dy

过滤

1filter()方法可以过滤掉不符合选择器条件的节点:

var langs = $('ul.lang li'); // 拿到JavaScript, Python, Swift, Scheme和Haskell

var a = langs.filter('.dy'); // 拿到JavaScript, Python, Scheme

//函数内部的this被绑定为DOM对象,不是jQuery对象

var langs = $('ul.lang li'); // 拿到JavaScript, Python, Swift, Scheme和Haskell

langs.filter(function () {

// this指的是标签为li的DOM对象

return this.innerHTML.indexOf('S') === 0; // 返回S开头的节点

}); // 拿到Swift, Scheme

2map()方法把一个jQuery对象包含的若干DOM节点转化为其他对象:

var langs = $('ul.lang li'); // 拿到JavaScript, Python, Swift, Scheme和Haskell

var arr = langs.map(function () {

return this.innerHTML;

}).get(); // 用get()拿到包含string的Array:['JavaScript', 'Python', 'Swift', 'Scheme', 'Haskell']

3、一个jQuery对象如果包含了不止一个DOM节点,first()last()slice()方法可以返回一个新的jQuery对象,把不需要的DOM节点去掉:

var langs = $('ul.lang li'); // 拿到JavaScript, Python, Swift, Scheme和Haskell

var js = langs.first(); // JavaScript,相当于$('ul.lang li:first-child')

var haskell = langs.last(); // Haskell, 相当于$('ul.lang li:last-child')

var sub = langs.slice(2, 4); // Swift, Scheme, 参数和数组的slice()方法一致

总结:

$("")是一个jquery对象,而不是一个dom element 
value是dom element的属性

jquery与之对应的是val

val() :获得第一个匹配元素的当前值。 
val(val):设置每一个匹配元素的值。

所以,代码应该这样写: 
取值:val = $("#id")[0].value; 或者$("#id").val();
赋值: $("#id")[0].value = "new
value"; 或者$("#id").val("new value");

JQuery入门篇的更多相关文章

  1. jquery(入门篇)无缝滚动

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  2. 从零开始学习jQuery (一) 入门篇

    本系列文章导航 从零开始学习jQuery (一) 入门篇 一.摘要 本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,  即使你会使用jQuery也能在阅读中发现些 ...

  3. jQuery学习笔记 - 基础知识扫盲入门篇

    jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...

  4. 1. web前端开发分享-css,js入门篇

    关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人与人的教育背景与成长环境心理活动都有差别,但就别人的心得再结合自己的特点,然后探索适合自己的学 ...

  5. web前端开发分享-css,js入门篇(转)

    转自:http://www.cnblogs.com/jikey/p/3600308.html 关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人 ...

  6. .NET Core实战项目之CMS 第四章 入门篇-Git的快速入门及实战演练

    写在前面 上篇文章我带着大家通过分析了一遍ASP.NET Core的源码了解了它的启动过程,然后又带着大家熟悉了一遍配置文件的加载方式,最后引出了依赖注入以及控制反转的概念!如果大家把前面几张都理解了 ...

  7. .NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

    写在前面 上面文章我给大家介绍了Dapper这个ORM框架的简单使用,大伙会用了嘛!本来今天这篇文章是要讲Vue的快速入门的,原因是想在后面的文章中使用Vue进行这个CMS系统的后台管理界面的实现.但 ...

  8. Web前端JQuery入门实战案例

    前端jquery入门到实战 为什么要学习Jquery?因为生活. 案例: <!DOCTYPE html> <html lang="zh-CN"> <h ...

  9. web前端开发分享-css,js入门篇

    学习没有捷径,但学习是有技巧与方法.   一,css入门篇:   推荐书籍:css哪些事儿,精通css. 理由:css那些事儿,他是一本介绍css基础类的书,是入门的经典读物. 系统的介绍了css的选 ...

随机推荐

  1. intellij idea 新建springboot工程pom.xml报错

    今天使用idea新建的springboot工程pom.xml文件报错如下 1. 问题 'settings.xml' has syntax errors less... (Ctrl+F1) Inspec ...

  2. Python--RE--?

    ?在re中默认匹配前一个字符0次或者1次 比如: aal? 默认匹配aal,或者aa    即整体匹配前一个字符串,但是可以舍弃最近的一个字符或者不舍弃 re模块 常用正则表达式符号 '.' 默认匹配 ...

  3. 一天撸完《 Learning Jupyter 5 2nd Edition》

    因为工作需要了解这个应用的大概功能. 网上找不到下载的,CSDN没积分. 最后,在道客上找到了这个PDF.花了一天时间浏览了一下, 只留意了python功能,其它语言略去. widget和jupyte ...

  4. 嵌入式linux开发uboot启动过程源码分析(一)

    一.uboot启动流程简介 与大多数BootLoader一样,uboot的启动过程分为BL1和BL2两个阶段.BL1阶段通常是开发板的配置等设备初始化代码,需要依赖依赖于SoC体系结构,通常用汇编语言 ...

  5. Java的修饰、继承、接口、抽象类

     1.private 修饰属性或者方法,只能在本类中被访问,定义后需要加get()set()方法,这样提高数据的安全性 私有属性虽然不能直接访问,但是其对象 或者 子类对象可以通过公有方法进行设值和获 ...

  6. SDSC 2018 day2解题报告

    目录 10.12考试总结 T1 最近公共祖先 错误原因 T2 即时战略 T3 欧皇 10.12考试总结 T1 最近公共祖先 预估得分: 100 实际得分: 20 最大得分: 100 用时:1小时10分 ...

  7. ZROI 暑期高端峰会 A班 Day3 图论

    最短路 NOI2019 D2T1 弹跳 KD 树 线段树套set -> 线段树套并查集? POI2014/2015 ??? \(n\) 个点 \(m\) 条边 DAG.求删掉每个点后 \(1\) ...

  8. DOM操作 三大家族

    clientHeight     获取对象的高度,不计算任何边距.边框.滚动条,但包括该对象的补白.   clientLeft     获取    offsetLeft     属性和客户区域的实际左 ...

  9. WebBrowser内存泄露

    使用WebBrowser控件开发的程序,占用内存会随着时间不停增长,最终内存溢出导致崩溃.究其原因是由于其自身的缺陷造成的.每一次加载新页面,WebBrowser就会多占用10-20M内存,有资料说是 ...

  10. vim常用命令整理

    #创建文件 vim test.txt vi test.txt touch test.txt #在vim中要想退出,先按[esc],再输入如下命令 [:wq]保存并退出 [:q]退出,未修改 [:q!] ...