jquery append()详解
1 http://www.365mini.com/page/jquery-append.htm
2 http://blog.csdn.net/chaiyining007/article/details/8213699
jq1.7.1这个版本为例。
首先我们来看下jq api的说明:向每个匹配的元素内部追加内容。
这个操作与对指定的元素执行appendChild方法,将它们添加到文档中的情况类似。
这个方法接收1个参数:content,接受类型有4种(3种从1.0就有了,function从1.4之后开始有)
String:字符串,这个容易理解就是可以直接$("选择器").append("aaaabbbbbcccc");这么写,当然jq内部还支持$("选择器").append('<a href="#"></a>');这种html标签的字符串,至于性能方面咋们后面看源码的时候在细论。
Element:节点,这个也容易理解就是dom节点么基本上俺是写成,$("选择器").append(document.getElementsByTagName("a"))这类,不过这么写的同学要注意一点,这么写会将原来位置的dom给“剪切”到选择器底部,请允许我这么形容。
jQuery:jQuery对象,这注意这个对象是jq选择器加工过的对象,比如$("选择器1").append($(“选择器2”));而不是$("选择器1").append($);写到这俺笑了,应该没人写append($)这个是吧。
function(index, html):一个function对象(参数后面讲),可以写成$("选择器").append(function(index,html){return ""});其中return "" 可以省略,任何函数都有返回值,没写return就会返回undefined,这个貌似高程或者权威指南有讲,具体哪写的,俺也忘记了。index参数为对象在这个集合中的索引值,要解释这句话,我们看个例子吧
- var _body=$("body");
- _body.html('');//清空body
- _body.append("<div></div><div></div>");//插入2个空div
- $("div").append(function(){return "a"});//我们要用结果猜个答案,虽然不是必须用这个例子,不过反正到这了 就这么写了
看到结果,俺猜append方法内部对整个选择器进行了遍历,然后插入了函数返回的东西。
所以index和html很容易理解了,就是在便利过程中的index和index对应的原先的html(插入之前);
最后讲一下,就是jq本身就是链式调用,所以append()返回的是选择器选择的对象被插之后的新对象,讲的好邪恶。
可以$("选择器").append().append().append().......................,不过一般都不会这么玩吧?
解释完API我们来看看源码
看到这个截图...好吧我们继续往下看。
- domManip: function (args, table, callback) {
- //定义6个变量,我们先不管这些变量干嘛。
- var results, first, fragment, parent,
- value = args[0],/*args参数在append调用的时候其实只有1个参数*/
- scripts = [];
- /*
- 进行了各种判断
- 1、!jQuery.support.checkClone:确保文档碎片还没有被克隆(作用在后面)
- 2、arguments.length === 3,确保调用domManip这个函数只有3个参数,否则会往后面走,这个很妙
- 3、typeof value === "string"确认你的参数是string类型
- 4、rchecked.test(value)
- */
- if (!jQuery.support.checkClone && arguments.length === 3 && typeof value === "string" && rchecked.test(value)) {
- //遍历选择器,看来我前面的猜测对了
- return this.each(function () {
- //看每次循环都调用了这个domManip,但是这些调用不会进入这个if,为什么?仔细看上面的注释与下面的调用
- jQuery(this).domManip(args, table, callback, true);
- });
- }
- //如果参数类型是function的
- if (jQuery.isFunction(value)) {
- //还是遍历
- return this.each(function (i) {
- var self = jQuery(this);
- /*
- 记得function的返回值吗?这边就把那边的返回值存到args[0]里面了
- table ? self.html() : undefined;这句话看不懂?table这个变量,在append调用domManip时已经写死了是true
- 所以在执行function类型参数的时候那个index和html是什么这边已经很明显了
- */
- args[0] = value.call(this, i, table ? self.html() : undefined);
- //取到插入的内容之后,重复第一步......
- self.domManip(args, table, callback);
- });
- }
- /*
- 到了这里,已经确保你取到了function中返回的string
- 上面的各种判断已经把你参数处理成接下去想要的,淡定的往下看吧
- if (this[0]) 这个判断。。。确保选择器存在,为什么不放最前面?
- */
- if (this[0]) {
- /*
- 取父级节点
- &&运算符就是
- 0&&1=0
- 1&&2=2
- 0&&0=0
- */
- parent = value && value.parentNode;
- // If we're in a fragment, just use that instead of building a new one
- /*
- 如果已经有元素碎片了就用原来的,不然就新建一个
- */
- if (jQuery.support.parentNode && parent && parent.nodeType === 11 && parent.childNodes.length === this.length) {
- results = { fragment: parent };
- } else {
- results = jQuery.buildFragment(args, this, scripts);
- }
- fragment = results.fragment;
- //取碎片中最后一个
- if (fragment.childNodes.length === 1) {
- first = fragment = fragment.firstChild;
- } else {
- first = fragment.firstChild;
- }
- //存在最后一个节点
- if (first) {
- //确保最后一个元素是tr?
- table = table && jQuery.nodeName(first, "tr");
- for (var i = 0, l = this.length, lastIndex = l - 1; i < l; i++) {
- callback.call(
- table ?
- root(this[i], first) :
- this[i],
- // Make sure that we do not leak memory by inadvertently discarding
- // the original fragment (which might have attached data) instead of
- // using it; in addition, use the original fragment object for the last
- // item instead of first because it can end up being emptied incorrectly
- // in certain situations (Bug #8070).
- // Fragments from the fragment cache must always be cloned and never used
- // in place.
- results.cacheable || (l > 1 && i < lastIndex) ?
- jQuery.clone(fragment, true, true) :
- fragment
- );
- }
- }
- /*插入脚本文件的话jq会帮你去请求的*/
- if (scripts.length) {
- jQuery.each(scripts, function (i, elem) {
- if (elem.src) {
- jQuery.ajax({
- type: "GET",
- global: false,
- url: elem.src,
- async: false,
- dataType: "script"
- });
- } else {
- jQuery.globalEval((elem.text || elem.textContent || elem.innerHTML || "").replace(rcleanScript, "/*$0*/"));
- }
- if (elem.parentNode) {
- elem.parentNode.removeChild(elem);
- }
- });
- }
- }
- return this;
- }
在往里面还有个底层buildFragment方法,我稍微看了,解释起来颇为费劲。
jquery append()详解的更多相关文章
- jQuery.validator 详解二
前言:上一篇详细的介绍了jQuery.validator( 版本v1.13.0 )的验证规则,这一篇重点讲述它的源码结构,及如何来对元素进行验证,错误消息提示的内部实现 一.插件结构(组织方式) 在讲 ...
- jQuery.validator 详解
jQuery.validator 详解二 前言:上一篇详细的介绍了jQuery.validator( 版本v1.13.0 )的验证规则,这一篇重点讲述它的源码结构,及如何来对元素进行验证,错误消息提示 ...
- jQuery:详解jQuery中的事件(二)
上一篇讲到jQuery中的事件,深入学习了加载DOM和事件绑定的相关知识,这篇主要深入讨论jQuery事件中的合成事件.事件冒泡和事件移除等内容. 接上篇jQuery:详解jQuery中的事件(一) ...
- jquery方法详解
jquery方法详解 http://www.365mini.com/doc
- Jquery 选择器 详解 js 判断字符串是否包含另外一个字符串
Jquery 选择器 详解 在线文档地址:http://tool.oschina.net/apidocs/apidoc?api=jquery 各种在线工具地址:http://www.ostools ...
- [转载]JavaEE学习篇之——JQuery技术详解
原文链接:http://blog.csdn.net/jiangwei0910410003/article/details/32102187 1.简介2.工具3.jQuery对象 1.DOM对象转化成j ...
- J2EE学习篇之--JQuery技术详解
前面我们讲解了的J2EE的技术都是服务端的技术,下面我们来看一下前端的一些开发技术,这一篇我们来看一下jQuery技术 简介: jQuery由美国人John Resig创建,至今已吸引了来自世界各地的 ...
- JQuery数组详解(含实例)
<!doctype html>jQuery数组处理详解(含实例演示)@Mr.Think 演示所用数组 var _mozi=['墨家','墨子','墨翟','兼爱非攻','尚同尚贤']; 1 ...
- jquery扩展函数详解(我的人生颠覆)
作者:zuoxiaolong8810(左潇龙),转载请注明出处,特别说明:本博文来自博主原博客,为保证新博客中博文的完整性,特复制到此留存,如需转载请注明新博客地址即可. 上次分析了jquery的源码 ...
随机推荐
- [OrangePi] Installation on internal EMMC
Install the image on SD Card as described above Boot your Orange PI board from SD Card Run: sudo ins ...
- SQL Server数据库的三种恢复模式:简单恢复模式、完整恢复模式和大容量日志恢复模式(转载)
SQL Server数据库有三种恢复模式:简单恢复模式.完整恢复模式和大容量日志恢复模式: 1.Simple 简单恢复模式, Simple模式的旧称叫”Checkpoint with truncate ...
- OpenStack 界面开发中response.body的中文编码问题
Contents [hide] 1 问题的引入= 1.1 解决办法 2 用户限制输入中文 3 不限制用户输入,呈现上修改 问题的引入= G在我们创建虚拟机的时候,会设置虚拟机的名称,描述,如果没有限制 ...
- React+Node.js+Express+mongoskin+MongoDB
首发:个人博客,更新&纠错&回复 采用React + Node.js + Express + mongoskin + MongoDB技术开发的一个示例,演示地址在这里,项目源码在这里. ...
- APP的UI测试要点
1.文字显示是否正确 比如与需求图片对比是否正确,无错别字 2.对齐方式是否正确 3.图片 图片显示的篇幅不要太大. 4.颜色是否正确 颜色与需求规定的是否一致
- 图像处理工具包ImagXpress中如何定义查看器的属性
想要在图像处理控件ImagXpress中查看一个图像,首先需要创建一个查看器,之后你可以按照你自身的需要,来定义查看器的属性. 创建查看器 想要动态的创建一个查看器,需要先定义一个新的mageXVie ...
- 使用jprofiler8远程监控weblogic的配置方法
jprofiler8的注册码:L-Larry_Lau@163.com#36573-fdkscp15axjj6#25257 未完待续
- oracle 日期格式
oracle 日期格式 to_date("要转换的字符串","转换的格式") 两个参数的格式必须匹配,否则会报错. 即按照第二个参数的格式解释第一个参数. ...
- win8以上版本离线安装.NET
方法一.C盘自带.NET 3.5,安装系统以后直接安装.NET 3.5. 1.按下:win+x,点击“命令提示符(管理员), 2.输入或复制以下代码(不可漏空格):dism.exe / ...
- js实现鼠标的滑动
js实现鼠标的滑动 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://w ...