jQuery修改DOM结构_动力节点Java学院整理


Posted in jQuery onJuly 05, 2017

直接使用浏览器提供的API对DOM结构进行修改,不但代码复杂,而且要针对浏览器写不同的代码。

有了jQuery,我们就专注于操作jQuery对象本身,底层的DOM操作由jQuery完成就可以了,这样一来,修改DOM也大大简化了。

添加DOM

要添加新的DOM节点,除了通过jQuery的html()这种暴力方法外,还可以用append()方法,例如:

<div id="test-div">
  <ul>
    <li><span>JavaScript</span></li>
    <li><span>Python</span></li>
    <li><span>Swift</span></li>
  </ul>
</div>

如何向列表新增一个语言?首先要拿到<ul>节点:

var ul = $('#test-div>ul');

然后,调用append()传入HTML片段:

ul.append('<li><span>Haskell</span></li>');

除了接受字符串,append()还可以传入原始的DOM对象,jQuery对象和函数对象:

// 创建DOM对象:
var ps = document.createElement('li');
ps.innerHTML = '<span>Pascal</span>';
// 添加DOM对象:
ul.append(ps);
// 添加jQuery对象:
ul.append($('#scheme'));
// 添加函数对象:
ul.append(function (index, html) {
  return '<li><span>Language - ' + index + '</span></li>';
});

传入函数时,要求返回一个字符串、DOM对象或者jQuery对象。因为jQuery的append()可能作用于一组DOM节点,只有传入函数才能针对每个DOM生成不同的子节点。

append()把DOM添加到最后,prepend()则把DOM添加到最前。

另外注意,如果要添加的DOM节点已经存在于HTML文档中,它会首先从文档移除,然后再添加,也就是说,用append(),你可以移动一个DOM节点。

如果要把新节点插入到指定位置,例如,JavaScript和Python之间,那么,可以先定位到JavaScript,然后用after()方法:

var js = $('#test-div>ul>li:first-child');
js.after('<li><span>Lua</span></li>');

也就是说,同级节点可以用after()或者before()方法。

删除节点

要删除DOM节点,拿到jQuery对象后直接调用remove()方法就可以了。如果jQuery对象包含若干DOM节点,实际上可以一次删除多个DOM节点:

var li = $('#test-div>ul>li');
li.remove(); // 所有<li>全被删除

以上所述是小编给大家介绍的jQuery修改DOM结构的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

jQuery 相关文章推荐
jquery实现tab键进行选择后enter键触发click行为
Mar 29 jQuery
jquery中封装函数传递当前元素的方法示例
May 05 jQuery
jquery.masonry瀑布流效果
May 25 jQuery
jQuery滚动插件scrollable.js用法分析
May 25 jQuery
Spring shiro + bootstrap + jquery.validate 实现登录、注册功能
Jun 02 jQuery
简单实现jQuery手风琴效果
Aug 18 jQuery
React中jquery引用的实现方法
Sep 12 jQuery
jQuery简单实现向列表动态添加新元素的方法示例
Dec 25 jQuery
vue-cli 引入jQuery,Bootstrap,popper的方法
Sep 03 jQuery
jQuery实时统计输入框字数及限制
Jun 24 jQuery
jQuery编写QQ简易聊天框
Aug 27 jQuery
JQuery绑定事件四种实现方法解析
Dec 02 jQuery
jQuery实现返回顶部按钮和scroll滚动功能[带动画效果]
Jul 05 #jQuery
jquery拖动改变div大小
Jul 04 #jQuery
jQuery实现动态给table赋值的方法示例
Jul 04 #jQuery
jQuery操作DOM_动力节点Java学院整理
Jul 04 #jQuery
jQuery层级选择器_动力节点节点Java学院整理
Jul 04 #jQuery
jQuery简介_动力节点Java学院整理
Jul 04 #jQuery
jQuery查找和过滤_动力节点节点Java学院整理
Jul 04 #jQuery
You might like
PHP+.htaccess实现全站静态HTML文件GZIP压缩传输(一)
2007/02/15 PHP
PHP 加密与解密的斗争
2009/04/17 PHP
实现获取http内容的php函数分享
2014/02/16 PHP
php实现无限级分类查询(递归、非递归)
2016/03/10 PHP
thinkPHP+PHPExcel实现读取文件日期的方法(含时分秒)
2016/07/07 PHP
php中替换字符串函数strtr()和str_repalce()的用法与区别
2016/11/25 PHP
PHP静态延迟绑定和普通静态效率的对比
2017/10/20 PHP
FireFox中textNode分片的问题
2007/04/10 Javascript
23个Javascript弹出窗口特效整理
2011/02/25 Javascript
jQuery Tools tab使用介绍
2012/07/14 Javascript
javascript设计模式之解释器模式详解
2014/06/05 Javascript
js时钟翻牌效果实现代码分享
2020/07/31 Javascript
JavaScript知识点总结之如何提高性能
2016/01/15 Javascript
touch.js 拖动、缩放、旋转 (鼠标手势)功能代码
2017/02/04 Javascript
基于vue实现多引擎搜索及关键字提示
2017/03/16 Javascript
微信小程序利用co处理异步流程的方法教程
2017/05/20 Javascript
JavaScript高阶函数_动力节点Java学院整理
2017/06/28 Javascript
jquery+css实现下拉列表功能
2017/09/03 jQuery
jQuery选择器之子元素过滤选择器
2017/09/28 jQuery
JS写谷歌浏览器chrome的外挂实例
2018/01/11 Javascript
JS实现的汉字与Unicode码相互转化功能分析
2018/05/25 Javascript
Vue props用法详解(小结)
2018/07/03 Javascript
学习python 之编写简单乘法运算题
2016/02/27 Python
详解python进行mp3格式判断
2016/12/23 Python
Python+OpenCV人脸检测原理及示例详解
2020/10/19 Python
python 时间信息“2018-02-04 18:23:35“ 解析成字典形式的结果代码详解
2018/04/19 Python
浅谈Python接口对json串的处理方法
2018/12/19 Python
详解用Python为直方图绘制拟合曲线的两种方法
2019/08/21 Python
Python开发之基于模板匹配的信用卡数字识别功能
2020/01/13 Python
python主要用于哪些方向
2020/07/05 Python
Html5元素及基本语法详解
2016/08/02 HTML / CSS
泰国汽车、火车和轮渡票预订网站:Bus Online Ticket
2017/09/09 全球购物
软件设计的目标是什么
2016/12/04 面试题
自考生自我鉴定范文
2013/10/01 职场文书
统计专业自荐书
2014/07/06 职场文书
Java+swing实现抖音上的表白程序详解
2022/06/25 Java/Android