jQuery中DOM树操作之使用反向插入方法实例分析


Posted in Javascript onJanuary 23, 2015

本文实例讲述了jQuery中DOM树操作之使用反向插入方法。分享给大家供大家参考。具体分析如下:

使用反向插入方法

这里我们先把创建的内容插人到元素前面,然后再把同一个元素插人到文档 中的另一个位置。通常,当在jQuery中操作元素时,利用连缀方法更简洁也更有效。可是我们现在没有办法这样做,因为this是.insertBefore()的目标,是.appendTo()的内容。此时,利 用反向插入方法,可以帮我们解决问题。

像.insertBefore()和.appendTo()这样的插人方法,一般都有一个对应的反向方法。反 向方法也执行相同的操作,只不过“目标”和“内容”正好相反。例如:

$('<p>Hello</p>').appendTo('#container');

与下面的代码结果一样:

$('#container').append('<p>Hello</p>');

下面我们就使用.before()代替.insertBefore()来重构代码,参见如下代码:

$(document).ready(function() {

var $notes = $('<ol id="notes"></ol>')

.insertBefore('#footer');

$('span.footnote').each(function(index) {

$(this)

.before('<sup>' + (index + 1) + '</sup>')

.appendTo($notes)

.wrap('<li></li>');

});

});

插入方法回调

反向插入方法可以接受一个函数作为参数,与.attr()和.css()方法类似。 这个传入的函数会针对每个目标元素调用,返回被插入的HTML字符串。在此其 实也可以使用这个技术,但由于这样就需要对每个脚注都重复一遍相同的操作, 所以还是使用一个.each()方法来得更清晰。

现在,我们可以考虑最后一步了:在正文中相应的位置创建指向匹配脚注的链接和在脚注中 创建指向正文位置的链接。为此,每个脚注需要4处标记:两个链接,一个在正文中,一个在脚 注中;以及两个id属性。因为这样一来,传人.before()方法的参数会变得复杂,所以有必要 在这里使用一种新的创建字符串的方法。
在上面的代码中,我们使用了 操作符来拼接字符串。使用+操作符虽然没有问题,但
如果要拼接的字符串太多,那看起来就会很乱。所以,我们在这里使用数组的.join()方法来构 建一个更大的数组。换句话说,下面的两行代码结果相同。

var str = 'a' + 'b' + 'c';

var str = ['a', 'b', 'c'].join('');

虽然这个例子要求输人更多字符,但使用.join()方法可以避免因要拼接的字符串过多而引 起混乱。下面我们再看看示例代码吧,如下代码就是使用.join()创建字符串的过程。

$(document).ready(function() {

var $notes = $('<ol id="notes"></ol>') .insertBefore('#footer'); $('span.footnote').each(function(index) { $(this)

.before([

'<sup>', index + 1,

'</sup>'

].join(''))

.appendTo($notes)

.wrap('<li></li>');

});

});

注意,由于数组的每个元素会分别执行运算,因此不再需要把index+1放在括号里了。 使用这种技巧,可以为脚注标签添加一个指向页面底部的链接和一个唯一的id值。同时在后 面的方法中,也要给<li>元素中添加相应的id属性,以便该链接有匹配的目标,参见如下代码:

$(document).ready(function() {

var $notes = $('<ol id="notes"></ol>') .insertBefore('#footer'); $('span.footnote').each(function(index) { $(this)

.before([

'<a href="#footnote-', index + 1,

'"id="context-', index + 1,

'"class="context">',

'<sup>', index + 1,

'</sup></a>'

].join(''))

.appendTo($notes)

.wrap('<li id=Mfootnote-' + (index + 1) + IM></li>');

});

});

添加了这些标记之后,每个脚注标签就有了指向页面底部对应脚注的链接。那么所剩的就是 在脚注中创建一个指向其上下文的链接了。为此,可以使用.appendTo()的反向方 法.append(),参见如下代码:

$(document).ready(function() {

var $notes = $('<ol id="notes__></ol>')

.insertBefore('#footer');

$('span.footnote').each(function(index) {

$(this)

.before([

'<a href="#footnote-', index + 1,

'"id="context-', index + 1,

'"class = "context__>',

'<sup>', index + 1,

'</sup></a>'

].join(''))

.appendTo($notes)

.append([

' (<a href="#context-', index + 1,

'__>context</a>)'

].join(''))

.wrap('<li id="footnote-' + (index + 1) + '__></li>');

});

});

注意,这里的href指向了脚注标签中的id。运行结果中,可以看到包含新链接的脚注。

希望本文所述对大家的jQuery程序设计有所帮助。

Javascript 相关文章推荐
JMenuTab简单使用说明
Mar 13 Javascript
JS 面向对象的5钟写法
Jul 31 Javascript
javascript客户端解决方案 缓存提供程序
Jul 14 Javascript
兼容FF和IE的动态table示例自写
Oct 21 Javascript
jquery操作select详解(取值,设置选中)
Feb 07 Javascript
Javascript的表单验证-提交表单
Mar 18 Javascript
老生常谈javascript变量的命名规范和注释
Sep 29 Javascript
解析javascript图片懒加载与预加载的分析总结
Oct 27 Javascript
原生js和css实现图片轮播效果
Feb 07 Javascript
javascript中mouseenter与mouseover的异同
Jun 06 Javascript
vue中七牛插件使用的实例代码
Jul 28 Javascript
vue操作动画的记录animate.css实例代码
Apr 26 Javascript
PHPExcel中的一些常用方法汇总
Jan 23 #Javascript
jQuery操作DOM之获取表单控件的值
Jan 23 #Javascript
使用angular写一个hello world
Jan 23 #Javascript
Javascript中的几种URL编码方法比较
Jan 23 #Javascript
jQuery源码分析之jQuery.fn.each与jQuery.each用法
Jan 23 #Javascript
AngularJS语法详解(续)
Jan 23 #Javascript
Jquery动态替换div内容及动态展示的方法
Jan 23 #Javascript
You might like
输入值/表单提交参数过滤有效防止sql注入的方法
2013/12/25 PHP
php删除数组元素示例分享
2014/02/17 PHP
php bootstrap实现简单登录
2016/03/08 PHP
magento后台无法登录解决办法的两种方法
2016/12/09 PHP
PHP自动补全表单的两种方法
2017/03/06 PHP
visual studio code 调试php方法(图文详解)
2017/09/15 PHP
JQuery动画和停止动画实例代码
2013/03/01 Javascript
js前台分页显示后端JAVA数据响应
2013/03/18 Javascript
Jquery实现动态切换图片的方法
2015/05/18 Javascript
浅谈JavaScript字符串拼接
2015/06/25 Javascript
分享纯手写漂亮的表单验证
2015/11/19 Javascript
详解JavaScript常量定义
2017/01/03 Javascript
Javarscript中模块(module)、加载(load)与捆绑(bundle)详解
2017/05/28 Javascript
Angularjs实现页面模板清除的方法
2018/07/20 Javascript
VUE v-model表单数据双向绑定完整示例
2019/01/21 Javascript
javascript头像上传代码实例
2019/09/28 Javascript
在vue和element-ui的table中实现分页复选功能
2019/12/04 Javascript
vue实现购物车的监听
2020/04/20 Javascript
[02:25]DOTA2英雄基础教程 虚空假面
2014/01/02 DOTA
浅谈MySQL中的触发器
2015/05/05 Python
浅谈python import引入不同路径下的模块
2017/07/11 Python
Android分包MultiDex策略详解
2017/10/30 Python
通过python+selenium3实现浏览器刷简书文章阅读量
2017/12/26 Python
python,Django实现的淘宝客登录功能示例
2019/06/12 Python
详解pandas数据合并与重塑(pd.concat篇)
2019/07/09 Python
python输出决策树图形的例子
2019/08/09 Python
Django框架HttpResponse对象用法实例分析
2019/11/01 Python
使用Pyhton 分析酒店针孔摄像头
2020/03/04 Python
python用700行代码实现http客户端
2021/01/14 Python
英国知名的皮手套品牌:Dents
2016/11/13 全球购物
纪检干部现实表现材料
2014/08/21 职场文书
纪检干部对照检查材料
2014/08/22 职场文书
2014年党员整改措施
2014/10/24 职场文书
2015国庆66周年宣传语
2015/07/14 职场文书
2016党员三严三实心得体会
2016/01/15 职场文书
R9700摩机记
2022/04/05 无线电