一、前言

在使用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包装集的函数的更多相关文章

  1. Jquery学习笔记:获取jquery对象的基本方法

    jquery最大的好处是将js对html页面的操作(读写)进行了封装,隔离了浏览器的差异性,并简化了操作,和提供了强大的功能. 在web页面中,所有的js操作都是围绕操作dom对象来的.而jquery ...

  2. jquery学习笔记---Dom操作

    一.DOM操作的分类 DOM(document object model)是一种与浏览器.平台.语言无关的接口,使用该接口可以访问页面中的·所有组件.DOM的操作可以分为DOM Core.HTML-D ...

  3. jQuery学习笔记1——操作属性

    一.获得和设置内容 三个简单实用的用于 DOM 操作的 jQuery 方法: text() - 设置或返回所选元素的文本内容, 得到匹配元素集合中每个元素的文本内容结合,包括他们的后代, 即由所有匹配 ...

  4. Jquery学习笔记:操作form表单元素之二(复选框和单选框)

    在上面文章的基础上,我们介绍如何操作表单元素中的 复选框和单选框. 一.复选框 <label> <input type="checkbox" id="i ...

  5. Jquery学习笔记:操作form表单元素之一(文本框和下拉框)

    一.概述 在web页面开发中,经常需要获取和设置表单元素的值(如文本框中的内容),特别是在ajax应用中,更是常态.本文系统的介绍下如何操作. 同操作其它html元素一样,操作的过程差不多. 第一步, ...

  6. Jquery学习笔记:利用jquery获取select下拉框的值

    jquery不是特别熟练,每次使用不常用的就要百度,特地记录下来. 我的下拉框是: <div class="form-group"> <select class= ...

  7. jQuery 学习笔记

    jQuery 学习笔记   一.jQuery概述    宗旨: Write Less, Do More.    基础知识:        1.符号$代替document.getElementById( ...

  8. jQuery学习笔记之DOM操作、事件绑定(2)

    jQuery学习笔记之DOM操作.事件绑定(2) --------------------学习目录------------------------ 4.DOM操作 5.事件绑定 源码地址: https ...

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

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

随机推荐

  1. [bzoj3991][SDOI2015]寻宝游戏_树链的并_倍增lca_平衡树set

    寻宝游戏 bzoj-3991 SDOI-2015 题目大意:题目链接. 注释:略. 想法:我们发现如果给定了一些点有宝物的话那么答案就是树链的并. 树链的并的求法就是把所有点按照$dfs$序排序然后相 ...

  2. Linux系统备份还原工具4(rsync/远程数据同步工具)

    rsync即是能备份系统也是数据同步的工具. 在Jenkins上可以使用rsync结合SSH的免密登录做数据同步和分发.这样一来可以达到部署全命令化,不需要依赖任何插件去实现. 命令参考:http:/ ...

  3. MongoDB小结15 - find【查询条件$ne】

    $ne表示不相等 db.user.find({"name":{"$ne":"william"}})

  4. 搭建ELK收集PHP的日志

    架构: filebeat --> redis -->logstash --> es --> kibana 每个客户端需要安装filebeat收集PHP日志 filebeat把收 ...

  5. 怎样把引用的jar包和本项目一起导出成jar文件

    之所以要导出Runnable JAR.是由于我们希望将引用到的Jar包与本项目一起进行导出,所以不要选Jar file 选File/Export...然后Java/Runnable JAR file, ...

  6. 向海量用户发送数据哪家最强?上QDN下载LTE Broadcast SDK!

    情境一: 在一个数万人的体育场内.作为一名观众你非常难看清运动员的面容.假设有了4G手机.你能够非常easy的打开直播应用.一边看直播讲解,一边体验现场气氛.但令人尴尬的是,现场几万人同一时候须要观看 ...

  7. 第二十七篇:Windows驱动中的PCI, DMA, ISR, DPC, ScatterGater, MapRegsiter, CommonBuffer, ConfigSpace

    近期有些人问我PCI设备驱动的问题, 和他们交流过后, 我建议他们先看一看<<The Windows NT Device Driver Book>>这本书, 个人感觉, 这本书 ...

  8. php与国付宝对接过程吐槽

    最近.我们在打造全国第一家互联网+风险管理平台(避险谷)时.须要与第三方支付平台"国付宝"进行在线交易对接. 之前对接过支付宝 .感觉还非常easy,拿到国付宝的接口文档.我晕啊. ...

  9. 【bzoj1150】[CTSC2007]数据备份Backup

    将k对点两两相连,求最小长度 易证得,最优方案中,相连的办公楼一定是取相邻的比取不相邻的要更优 然后就可以用贪心来做这道题了.. 将初始所有的线段放进堆里 每次取最短的线段进行连接,且ans+=a[i ...

  10. 【bzoj1029】[JSOI2007]建筑抢修

    按照t2从小到大排列之后贪心. 若当前任务可以插入,则插入. 若当前任务不可以插入,分两种情况: ①当前任务的耗时大于等于之前插入的任务的最大耗时:跳过当前任务 ②当前任务的耗时小于之前插入的任务的耗 ...