元素的操作:取值和赋值
操作网页元素,最常见的需求是取得它们的值,或者对它们进行赋值。
jQuery使用同一个函数,来完成取值(getter)和赋值(setter)。到底是取值还是赋值,由函数的参数决定。
$(‘h1’).html(); //html()没有参数,表示取出h1的值
$(‘h1’).html(‘Hello’); //html()有参数Hello,表示对h1进行赋值
常见的取值和赋值函数如下:
- .html() 返回或设置被选元素的内容 (inner HTML)
- .text() 取出或设置text内容
- .attr() 取出或设置某个属性的值
- .width() 取出或设置某个元素的宽度
- .height() 取出或设置某个元素的高度
- .val() 取出或设置html内容 取出某个表单元素的值
需要注意的是,如果结果集包含多个元素,那么赋值的时候,将对其中所有的元素赋值;取值的
时候 ,则是只取出第一个元素的值(.text()例外,它取出所有元素的text内容)。
元素的操作:移动
.insertAfter(),把div元素移动p元素后面:
$(‘div’).insertAfter(‘p’);
.after(),把p元素加到div元素前面:
$(‘p’).after(‘div’);
使用这种模式的操作方法,一共有四对 - .insertAfter()和.after():在现存元素的外部,从后面插入元素
- .insertBefore()和.before():在现存元素的外部,从前面插入元素
- .appendTo()和.append():在现存元素的内部,从后面插入元素
- .prependTo()和.prepend() :在现存元素的内部,从前面插入元素
元素的操作:复制、删除和创建
复制元素使用.clone()
删除元素使用.remove()和.detach()。两者的区别在于,前者不保留被删除元素的事件,
后者保留,有利于重新插入文档时使用。
清空元素内容(但是不删除该元素)使用.empty()。
创建新元素的方法非常简单,只要把新元素直接传入jQuery的构造函数就行了:
事件捕获与事件冒泡
事件捕获: 允许多个元素响应事件的一种策略。在事件捕获的过程中,事件首先会交给最外
层的元素,接着再交给更具体的元素。
事件冒泡:另外一种相反的策略叫时间冒泡,当事件发生时,会首先发送给最具体的元素,在这个元素获得响应机会之后,事件会向上冒泡到更一般的元素。事件冒泡有时候会产生副作用,导致始料不及的行为。
阻止事件冒泡的三种方法
指定默认操作
通过调用.preventDefault()方法可以在出发默认操作之前终止事件。
调用 event.stopPropagation()停止事件传播