jQuery学习之路(2)-DOM操作
▓▓▓▓▓▓ 大致介绍
jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象。
▓▓▓▓▓▓ jQuery中的DOM操作
看看DOM操作都有哪些
逐一来看
先写一份HTML代码,后面的代码将操作这份HTML代码
<p title="选择你最喜欢的水果">你最喜欢的水果?</p>
<ul>
<li title="苹果">苹果</li>
<li title="橘子">橘子</li>
<li title="菠萝">菠萝</li>
</ul>
▓▓▓▓▓▓ 查找节点
1、查找元素节点
查找节点可以用各种各样的选择器来查找
$('ul li');
2、查找属性节点
可以用attr()方法,参数是一个的时候是查找属性,两个的时候是设置属性
console.log($('li:eq(2)').attr('title'));//菠萝
▓▓▓▓▓▓ 查找节点
1、创建元素节点
var $li_1 = $('<li></li>');
2、创建文本节点
var $li_1 = $('<li>香蕉</li>');
3、创建属性节点
var $li_1 = $('<li title="香蕉">香蕉</li>');
▓▓▓▓▓▓ 插入节点
1、向每个匹配的元素追加内容
$('li:eq(1)').append('<p>香蕉</p>');
2、将匹配的元素追加到指定元素中
$('<p>香蕉</p>').appendTo('li:eq(1)');
这两种方法都是进行同一个操作,prepend()和prependTo()与上述方法类似,不同之处就是在元素内部前插入内容
3、在每个匹配的元素之后插入内容
$('li:eq(1)').after('<p>香蕉</p>');
4、将匹配的元素插入到指定的元素后面
$('<p>香蕉</p>').insertAfter('li:eq(1)');
这两种方法都是进行同一个操作,before()和insertBefore()与上述方法类似,不同之处就是在元素前插入内容
▓▓▓▓▓▓ 删除节点
1、remove()方法
当某个节点用了remove()方法之后,该节点所包含的所有后代节点都将同时删除。这个方法的返回值是一个指向已被删除的节点的引用,因此可以在后面再使用这些元素
var $li = $('li:eq(1)').remove();
$li.appendTo('ul');
remove()方法也可以选择性的删除元素
$('ul li').remove('li[title="菠萝"]');
2、detach()方法
detach()方法和remove()方法用法一样,不同点是detach()方法,所有绑定的事件、附加的数据等都会保留下来
$('ul li').click(function(){
alert($(this).html());
});
var $li = $('ul li:eq(1)').detach();
$li.appendTo('ul');//点击事件会保存下来
3、empty()方法
empty()方法并不是删除节点而是清空节点
$('ul li:eq(2)').empty();
▓▓▓▓▓▓ 复制节点
1、clone()方法
$('ul li').click(function(){
$(this).clone(true).appendTo($('ul'));
传入参数true时,会复制元素中所绑定的事件
▓▓▓▓▓▓ 替换节点
1、replaceWith()和replaceAll()
replaceWith()方法的作用是将所有匹配的元素都替换成指定的元素
$('p').replaceWith('<p>香蕉</p>');
replaceAll()方法只是将replaceWith()方法翻过来了
$('<p>香蕉</p>').replaceAll('p');
▓▓▓▓▓▓ 包裹节点
1、wrap()方法
将某个节点用其他的标记包裹起来,如果是一组节点,那么就会包裹这一组节点里的每个节点
$('li').wrap('<b></b>');
2、wrapAll()方法
与wrap()方法不同的是,即使是一组节点,也只会用一个节点包裹
$('li').wrapAll('<b></b>');
3、wrapInner()方法
将匹配的元素的子内容(包括文本节点)用其他结构化的标记包裹
▓▓▓▓▓▓ 属性操作
1、获取属性和设置属性
attr()方法传递一个参数的时候是获取属性,传递两个参数的时候是设置属性
$('p').attr('title','you title');
2、删除属性
removeAttr()方法
$('p').removeAttr('title');
▓▓▓▓▓▓ 样式操作
1、获取样式和设置样式
可以用attr()方法
2、追加样式
addClass()是在原有的样式上添加样式
$('p').addClass('another');
3、移除样式
removeClass()方法可以删除class属性,如果有多个需要删除要用空格将他们分隔,如果不传入参数则表示移除全部class
$('p').removeClass('another');
4、切换样式
toggle()方法是交替执行代码
$('p').toggle(function(){
// 函数1
},function(){
// 函数2
});
toggleClass()方法控制样式上的重复切换,如果类名存在就删除它,如果不在就添加它
$('p').toggleClass('another');
5、判断是否含有某个样式
hasClass()可以用来判断元素中时候含有某个class,如果有,返回true,否则,返回false
$('p').hasClass('another');
▓▓▓▓▓▓ 设置和获取HTML、文本和值
1、html()方法
此方法类似于innerHTML,可以用来读取或者设置某个元素中的HTML内容
$('p').html('<b>香蕉</b>');
2、text()方法
类似于innerText,可以用来读取或者设置某个元素中的文本内容
$('p').text('hello');
3、val()方法
类似于value属性,可以用来设置和获取元素的值。如果元素为多选,则返回一个包含所有选择的值的数组
▓▓▓▓▓▓ 遍历节点
1、children()方法
该方法用于取得匹配元素的子元素集合,值考虑子元素不考虑其他后代元素
$('ul').children();
2、next()方法
匹配元素后面紧邻的同辈元素
$('ul').next();
3、prev()方法
匹配元素前面紧邻的同辈元素
4、siblings()方法
匹配元素前后所有的同辈元素
5、closest()方法
该方法用于取得最近的匹配元素,首先检查当前元素是否匹配,如果匹配直接返回该元素,否则向上查找父级元素,逐级向上查找,如果什么都没有找到则返回一个空的jQuery对象。
6、parent()与parents()方法
parent()方法获得集合中每个匹配元素的父级元素
parents()方法获得集合中每个元素的祖先元素
▓▓▓▓▓▓ CSS-DOM操作
1、css()方法
可以获取元素的属性也可以设置元素的属性
$('p').css({fontSize:'20px',backgroundColor:'green'});
2、height()方法、innerHeight()方法和outerHeight()方法
height()方法是获取width属性,innerHeight()方法获取的是width + padding,outerHeight()方法获取的是width + padding + border
3、offset()方法
获取元素在当前可视区的相对偏移
4、position()方法
获取元素相对于最近的一个position样式属性设置为relative或者absolute的父元素的相对偏移
5、scrollTop和scrollLeft()方法
获取元素的滚动条距离顶端的距离和左侧的距离
jQuery学习之路(2)-DOM操作的更多相关文章
- jQuery学习之路(1)-选择器
▓▓▓▓▓▓ 大致介绍 终于开始了我的jQuery学习之路!感觉不能再拖了,要边学习原生JavaScript边学习jQuery jQuery是什么? jQuery是一个快速.简洁的JavaScript ...
- jQuery学习之------元素样式的操作
jQuery学习之------元素样式的操作 一..addClass( className )方法----增加样式 1.addClass( className ) : 为每个匹配元素所要增加的一个或多 ...
- jquery学习笔记(二):DOM元素操作
内容来自[汇智网]jquery学习课程 2.1 元素属性操作 1.获取元素的属性 语法:attr(name) 参数name表示属性的名称 2.设置元素的属性 单个属性设置语法:attr(key,val ...
- jQuery 学习之路(1):引子
一.主流 javascript 库 除 jQuery 外,还有 Prototype.Dojo.YUI.ExtJS.MooTools ,其中 Prototype 较老,结构设计较为松散,ExtJS 界面 ...
- 认识JQuery,JQuery的优势、语法、多库冲突、JS原生对象和JQuery对象之间相互转换和DOM操作,常用的方法
(一)认识JQuery JQuery是一个JavaScript库,它通过封装原生的JavaScript函数得到一套定义好的方法 JQuery的主旨:以更少的代码,实现更多的功能 (二)JQue ...
- JQuery选择器,事件,DOM操作,动画
JQuery是一个JavaScript代码库,或者是JavaScript框架: 1.选择器:(和CSS选择器一致) 基本选择器:ID选择器$('#div1');Class选择器('.div1');标签 ...
- javascript学习(二) DOM操作HTML
一:DOM操作HTML JavaScript能够改变页面中所有的HTML元素 JavaScript能够改变页面中所有的HTML属性 JavaScript能够改变页面中所有的CSS样式 JavaScri ...
- 【php学习之路】字符串操作
无论学习那种语言,字符串操作都是必备的基础.学php的时候总是会不知不觉的与C#比较,用起来总觉得怪怪的没有那么顺手,有些命名也差别很大,再加上很多函数命名是简写形式不百度下还真不知道什 ...
- jQuery 【事件】【dom 操作】
事件 hover( function(){},function(){}) -- 鼠标移入移出事件 toggle(function(){},function(){},function(){} ...
随机推荐
- 为你的Web程序加个启动画面
.Net开发者一定熟悉下面这个画面: 这就是宇宙第一IDE Visual Studio的启动画面,学名叫Splash Screen(或者Splash Window).同样,Javar们一定对Eclip ...
- ABP文档 - Hangfire 集成
文档目录 本节内容: 简介 集成 Hangfire 面板授权 简介 Hangfire是一个综合的后台作业管理器,可以在ABP里集成它替代默认的后台作业管理器,你可以为Hangfire使用相同的后台作业 ...
- HTML 事件(四) 模拟事件操作
本篇主要介绍HTML DOM中事件的模拟操作. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4. ...
- .Net 大型分布式基础服务架构横向演变概述
一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支持用户,订单,采购,物流,配送,财务等多个项目的协作,便于后续运营报表,分析,便于运维及监控. 二. 基础 ...
- 如何将VCSA添加到微软域控环境,并且实现微软域账号登陆vCenter
v:* { } o:* { } w:* { } .shape { } p.msonormal,li.msonormal,div.msonormal { margin: 0cm; margin-bott ...
- 一个诡异的COOKIE问题
今天下午,发现本地的测试环境突然跑不动了,thinkphp直接跑到异常页面,按照正常的排错思路,直接看thinkphp的log 有一条 [ error ] [2]setcookie() expects ...
- ASP.Net MVC——使用 ITextSharp 完美解决HTML转PDF(中文也可以)
前言: 最近在做老师交代的一个在线写实验报告的小项目中,有这么个需求:把学生提交的实验报告(HTML形式)直接转成PDF,方便下载和打印. 以前都是直接用rdlc报表实现的,可这次牵扯到图片,并且更为 ...
- 程序员必须要知道的Hadoop的一些事实
程序员必须要知道的Hadoop的一些事实.现如今,Apache Hadoop已经无人不知无人不晓.当年雅虎搜索工程师Doug Cutting开发出这个用以创建分布式计算机环境的开源软...... 1: ...
- web服务器集群
概述 集群和分布式都是从集中式进化而来的.分布式和集群会相互合作的,同时的集群和分布式.在这里重点说说集群 集群是什么? 集群能提高单位时间内处理的任务数量,提升服务器性能 有多台服务器去处理任务,但 ...
- jenkins无法重启tomcat的原因
在使用Hudson的执行sh脚本的时候,如果sh脚本是一个后台进程,如 Tomcat 这样的服务.如果使用Hudson的默认配置,会发现这些sh 进程有启动的过程,但是不会常驻后台,看Hudson 输 ...