jQuery学习笔记(3)-操作jQuery包装集的函数
一、前言
在使用jQuery选择器获取到jQuery包装集后,我们就要对这些包装集进行各种操作
二、创建新的元素
1.使用HTMLDOM创建元素
(1)什么是DOM
当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)
(2)使用HTML DOM创建元素
1 <div id="testDiv"></div>
2 <script>
3 var select = document.createElement("select");
4 select.options[0] = new Option("加载项1", "value1");
5 select.options[1] = new Option("加载项2", "value2");
6 select.size = "2";
7 var testDiv = document.getElementById("testDiv");
8 var object = testDiv.appendChild(select);
9 </script>
2.使用jQuery函数创建元素
1 <div id="testDiv"></div>
2 <script>
3 $("<select><option value ='value1'>加载项1</option><option value='value2'>加载项2</option></select>").appendTo($("#testDiv"))
4 </script>
5
(1)创建时注意
一定不要在页面加载时就改变页面的DOM结构,正确的做法是在页面加载完毕后添加或删除元素
方式一:所有资源完整加载后,再添加新的元素
缺点:如果某个图片或资源加载很长时间,就会显示一个不完整的页面
<script>
window.onload = function () {
$("<select><option value ='value1'>加载项1</option><option value='value2'>加载项2</option></select>").appendTo($("#testDiv"));
}
</script>
方式二:DOM完整加载后,再添加新的元素
<script>
$(document).ready(function () {
$("<select><option value ='value1'>加载项1</option><option value='value2'>加载项2</option></select>").appendTo($("#testDiv"));
});
</script>
或者使用简洁语法
<script>
$(function () {
$("<select><option value ='value1'>加载项1</option><option value='value2'>加载项2</option></select>").appendTo($("#testDiv"));
});
</script>
三、管理jQuery包装集的一些函数
1.过滤 Filtering
| $("p").eq(1) | 获取匹配的第二个元素 |
| $("p").filter(".selected") | 保留class为selected的元素 |
| $("div").filter(function (index) {return $("ol", this).size() == 0;}); | 保留子元素中不含有ol的元素 |
| $("input[type='checkbox']").parent().is("form") | 由于input元素的父元素是一个表单元素,所以返回true |
| $("p").append($("input").map(function () { return $(this).val(); }).get().join(", ")); | 把form中的每个input元素的值建立一个列表 |
| $("p").not( $("#selected")[0] ) | 从p元素中删除带有 select 的ID的元素 |
| $("p").slice(0, 1) | 选择第一个p元素 |
2.查找Finding
| $("p").add("<span>Again</span>") | 动态生成一个元素并添加至匹配的元素中 |
| $("div").children() | 查找DIV中的每个子元素 |
| $(document).bind("click", function (e) { $(e.target).closest("li").toggleClass("hilight"); }) | 为事件源最近的父类li对象更换样式 |
| $("p").contents().not("[nodeType=1]").wrap("<b/>") | 查找所有文本节点并加粗 |
| $("p").find("span") | 与$("p span")相同 |
| $("p").next() | 找到每个段落的后面紧邻的同辈元素 |
| $("div:first").nextAll().addClass("after") | 给第一个div之后的所有元素加个class |
| offsetParent( ) | |
| $("p").parent() | 查找每个段落的父元素 |
| $("span").parents() | 找到每个span元素的所有祖先元素 |
| $("p").prev() | 找到每个段落紧邻的前一个同辈元素 |
| $("div:last").prevAll().addClass("before") | 给最后一个之前的所有div加上一个class |
| $("div").siblings() | 找到每个div的所有同辈元素 |
3.串联 Chaining
| $("div").find("p").andSelf().addClass("border") | 选取所有div以及内部的p,并加上class |
| $("p").find("span").end() | 选取所有的p元素,查找并选取span子元素,然后再回过来选取p元素 |
四、参考文章
http://www.cnblogs.com/zhangziqiu/archive/2009/05/04/jQuery-Learn-3.html
jQuery学习笔记(3)-操作jQuery包装集的函数的更多相关文章
- Jquery学习笔记:获取jquery对象的基本方法
jquery最大的好处是将js对html页面的操作(读写)进行了封装,隔离了浏览器的差异性,并简化了操作,和提供了强大的功能. 在web页面中,所有的js操作都是围绕操作dom对象来的.而jquery ...
- jquery学习笔记---Dom操作
一.DOM操作的分类 DOM(document object model)是一种与浏览器.平台.语言无关的接口,使用该接口可以访问页面中的·所有组件.DOM的操作可以分为DOM Core.HTML-D ...
- jQuery学习笔记1——操作属性
一.获得和设置内容 三个简单实用的用于 DOM 操作的 jQuery 方法: text() - 设置或返回所选元素的文本内容, 得到匹配元素集合中每个元素的文本内容结合,包括他们的后代, 即由所有匹配 ...
- Jquery学习笔记:操作form表单元素之二(复选框和单选框)
在上面文章的基础上,我们介绍如何操作表单元素中的 复选框和单选框. 一.复选框 <label> <input type="checkbox" id="i ...
- Jquery学习笔记:操作form表单元素之一(文本框和下拉框)
一.概述 在web页面开发中,经常需要获取和设置表单元素的值(如文本框中的内容),特别是在ajax应用中,更是常态.本文系统的介绍下如何操作. 同操作其它html元素一样,操作的过程差不多. 第一步, ...
- Jquery学习笔记:利用jquery获取select下拉框的值
jquery不是特别熟练,每次使用不常用的就要百度,特地记录下来. 我的下拉框是: <div class="form-group"> <select class= ...
- jQuery 学习笔记
jQuery 学习笔记 一.jQuery概述 宗旨: Write Less, Do More. 基础知识: 1.符号$代替document.getElementById( ...
- jQuery学习笔记之DOM操作、事件绑定(2)
jQuery学习笔记之DOM操作.事件绑定(2) --------------------学习目录------------------------ 4.DOM操作 5.事件绑定 源码地址: https ...
- jQuery学习笔记 - 基础知识扫盲入门篇
jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...
随机推荐
- zoj2853 Evolution
给定一个进化的矩阵图,问在m次之后最终的物种有多少个,实际上这和线性代数及其应用里的一个例题是一样的...总之就相当于煞笔的套个矩阵不断去乘m次,然后每次都会根据得到进化后各物种的个数,矩阵快速幂求一 ...
- Linux系统备份还原工具2(TAR/压缩工具)
相比DD备份还原工具,TAR压缩还原工具更加小巧和灵活,但是不能备份MBR.当然可以通过重新安装GRUB来解决MBR的这一问题.同时,TAR的做法也是官方推荐的. 注意:一个硬盘启动时最新经过MBR( ...
- FTP指令说明
安装vsftpd: listen=YES: 是否监听端口 anonymous_enable=NO: 是否启用匿名用户 local_enable=YES: 是否允许本地用户登录 write_enable ...
- nodejs参考文章
http://www.cnblogs.com/lily1010/p/6683987.html https://manlili.github.io/2015/04/06/Node%E5%85%A5%E9 ...
- PHP导入和导出CSV文件
CREATE TABLE `student` ( `id` ) NOT NULL auto_increment, `name` varchar() NOT NULL, `sex` varchar() ...
- CLR-基元类型以及溢出检查 (CLR-Via-C#) 类型基础
CLR-基元类型以及溢出检查 =========(CLR via C#阅读笔记)======== 基元类型(primitive type): 基元类型也不做过多的解释,举个例子即可清晰的辨别 在j ...
- C# 最基本的涉及模式(单例模式) C#种死锁:事务(进程 ID 112)与另一个进程被死锁在 锁 | 通信缓冲区 资源上,并且已被选作死锁牺牲品。请重新运行该事务,解决方案: C#关闭应用程序时如何关闭子线程 C#中 ThreadStart和ParameterizedThreadStart区别
C# 最基本的涉及模式(单例模式) //密封,保证不能继承 public sealed class Xiaohouye { //私有的构造函数,保证外部不能实例化 private ...
- SpringMVC 学习笔记(五) 基于RESTful的CRUD
1.1. 概述 当提交的表单带有_method字段时,通过HiddenHttpMethodFilter 将 POST 请求转换成 DELETE.PUT请求,加上@PathVariable注解从而实现 ...
- FFmpeg将多张图片合成视频 子视频合并
FFmpeg将多张图片合成视频 - CSDN博客 https://blog.csdn.net/wangshuainan/article/details/77914508 Slideshow – FFm ...
- Struts数据验证
Action类继承了ActionSupport类,而该类实现了Action.Validateable.ValidationAware.TextProvider.LocaleProvider和Seria ...