[jQuery教程]jQuery的属性与样式(三)

目录
文章目录隐藏
  1. .attr()与.removeAttr()
  2. html()及.text()
  3. .val()
  4. .addClass()
  5. 删除样式 .removeClass()
  6. 切换样式 .toggleClass()
  7. 样式操作 .css()
  8. .css()与.addClass()设置样式的区别
  9. 元素的数据存储

[jQuery 教程]jQuery 的属性与样式(三)

.attr()与.removeAttr()

每个元素都有一个或者多个特性,这些特性的用途就是给出相应元素或者其内容的附加信息。如:在 img 元素中,src 就是元素的特性,用来标记图片的地址。

操作特性的 DOM 方法主要有 3 个,getAttribute 方法、setAttribute 方法和 removeAttribute 方法,就算如此在实际操作中还是会存在很多问题,这里先不说。而在 jQuery 中用一个 attr()与 removeAttr()就可以全部搞定了,包括兼容问题

jQuery 中用 attr()方法来获取和设置元素属性,attr 是 attribute(属性)的缩写,在 jQuery DOM 操作中会经常用到 attr()

attr()有 4 个表达式

  1. attr(传入属性名):获取属性的值
  2. attr(属性名, 属性值):设置属性的值
  3. attr(属性名,函数值):设置属性的函数值
  4. attr(attributes):给指定元素设置多个属性值,即:{属性名一: “属性值一” , 属性名二: “属性值二” , … … }

removeAttr()删除方法

.removeAttr( attributeName ) : 为匹配的元素集合中的每个元素中移除一个属性(attribute)

优点

attr、removeAttr 都是 jQuery 为了属性操作封装的,直接在一个 jQuery 对象上调用该方法,很容易对属性进行操作,也不需要去特意的理解浏览器的属性名不同的问题。

注意:

dom 中有个概念的区分:Attribute 和 Property 翻译出来都是“属性”,《js 高级程序设计》书中翻译为“特性”和“属性”。简单理解,Attribute 就是 dom 节点自带的属性

例如:html 中常用的 id、class、title、align 等

<div id="mybj" title="码云笔记"></div>

而 Property 是这个 DOM 元素作为对象,其附加的内容,例如,tagName, nodeName, nodeType,, defaultChecked, 和 defaultSelected 使用.prop()方法进行取值或赋值等

获取 Attribute 就需要用 attr,获取 Property 就需要用 prop

html()及.text()

读取、修改元素的 html 结构或者元素的文本内容是常见的 DOM 操作,jQuery 针对这样的处理提供了 2 个便捷的方法.html()与.text()

.html()方法

获取集合中第一个匹配元素的 HTML 内容 或 设置每一个匹配元素的 html 内容,具体有 3 种用法:

  1. .html() 不传入值,就是获取集合中第一个匹配元素的 HTML 内容
  2. .html( htmlString ) 设置每一个匹配元素的 html 内容
  3. .html( function(index, oldhtml) ) 用来返回设置 HTML 内容的一个函数

注意事项:

.html()方法内部使用的是 DOM 的 innerHTML 属性来处理的,所以在设置与获取上需要注意的一个最重要的问题,这个操作是针对整个 HTML 内容(不仅仅只是文本内容)

.text()方法

得到匹配元素集合中每个元素的文本内容结合,包括他们的后代,或设置匹配元素集合中每个元素的文本内容为指定的文本内容。,具体有 3 种用法:

  1. .text() 得到匹配元素集合中每个元素的合并文本,包括他们的后代
  2. .text( textString ) 用于设置匹配元素内容的文本
  3. .text( function(index, text) ) 用来返回设置文本内容的一个函数

注意事项:
.text()结果返回一个字符串,包含所有匹配元素的合并文本
.html 与.text 的异同:

  1. .html 与.text 的方法操作是一样,只是在具体针对处理对象不同
  2. .html 处理的是元素内容,.text 处理的是文本内容
  3. .html 只能使用在 HTML 文档中,.text 在 XML 和 HTML 文档中都能使用
  4. 如果处理的对象只有一个子文本节点,那么 html 处理的结果与 text 是一样的
  5. 火狐不支持 innerText 属性,用了类似的 textContent 属性,.text()方法综合了 2 个属性的支持,所以可以兼容所有浏览器

.val()

jQuery 中有一个.val()方法主要是用于处理表单元素的值,比如 input, select 和 textarea。

.val()方法

  1. .val()无参数,获取匹配的元素集合中第一个元素的当前值
  2. .val( value ),设置匹配的元素集合中每个元素的值
  3. .val( function ) ,一个用来返回设置值的函数

 注意事项:

  1. 通过.val()处理 select 元素, 当没有选择项被选中,它返回 null
  2. .val()方法多用来设置表单的字段的值
  3. 如果 select 元素有 multiple(多选)属性,并且至少一个选择项被选中, .val()方法返回一个数组,这个数组包含每个选中选择项的值

.html(),.text()和.val()的差异总结:

  1. .html(),.text(),.val()三种方法都是用来读取选定元素的内容;只不过.html()是用来读取元素的 html 内容(包括 html 标签),.text()用来读取元素的纯文本内容,包括其后代元素,.val()是用来读取表单元素的”value”值。其中.html()和.text()方法不能使用在表单元素上,而.val()只能使用在表单元素上;另外.html()方法使用在多个元素上时,只读取第一个元素;.val()方法和.html()相同,如果其应用在多个元素上时,只能读取第一个表单元素的”value”值,但是.text()和他们不一样,如果.text()应用在多个元素上时,将会读取所有选中元素的文本内容。
  2. .html(htmlString),.text(textString)和.val(value)三种方法都是用来替换选中元素的内容,如果三个方法同时运用在多个元素上时,那么将会替换所有选中元素的内容。
  3. .html(),.text(),.val()都可以使用回调函数的返回值来动态的改变多个元素的内容。

.addClass()

通过动态改变类名(class),可以让其修改元素呈现出不同的效果。在 HTML 结构中里,多个 class 以空格分隔,当一个节点(或称为一个标签)含有多个 class 时,DOM 元素响应的 className 属性获取的不是 class 名称的数组,而是一个含有空格的字符串,这就使得多 class 操作变得很麻烦。同样的 jQuery 开发者也考虑到这种情况,增加了一个.addClass()方法,用于动态增加 class 类名

.addClass( className )方法

  1. .addClass( className ) : 为每个匹配元素所要增加的一个或多个样式名
  2. .addClass( function(index, currentClass) ) : 这个函数返回一个或更多用空格隔开的要增加的样式名

注意事项:
.addClass()方法不会替换一个样式类名。它只是简单的添加一个样式类名到元素上
简单的描述下:在 p 元素增加一个 newClass 的样式

<p class="orgClass">
$("p").addClass("newClass")

那么 p 元素的 class 实际上是 class=”orgClass newClass”样式只会在原本的类上继续增加,通过空格分隔

删除样式 .removeClass()

jQuery 通过.addClass()方法可以很便捷的增加样式。如果需要样式之间的切换,同样 jQuery 提供了一个很方便的.removeClass(),它的作用是从匹配的元素中删除全部或者指定的 class

.removeClass( )方法

  1. .removeClass( [className ] ):每个匹配元素移除的一个或多个用空格隔开的样式名
  2. .removeClass( function(index, class) ) : 一个函数,返回一个或多个将要被移除的样式名

注意事项

如果一个样式类名作为一个参数,只有这样式类会被从匹配的元素集合中删除 。 如果没有样式名作为参数,那么所有的样式类将被移除。

切换样式 .toggleClass()

在做某些效果的时候,可能会针对同一节点的某一个样式不断的切换,也就是 addClass 与 removeClass 的互斥切换,比如隔行换色效果

jQuery 提供一个 toggleClass 方法用于简化这种互斥的逻辑,通过 toggleClass 方法动态添加删除 Class,一次执行相当于 addClass,再次执行相当于 removeClass

.toggleClass( )方法:在匹配的元素集合中的每个元素上添加或删除一个或多个样式类,取决于这个样式类是否存在或值切换属性。即:如果存在(不存在)就删除(添加)一个类

  1. .toggleClass( className ):在匹配的元素集合中的每个元素上用来切换的一个或多个(用空格隔开)样式类名;
  2. .toggleClass( className, switch ):一个布尔值,用于判断样式是否应该被添加或移除;
  3. .toggleClass( [switch ] ):一个用来判断样式类添加还是移除的 布尔值;
  4. .toggleClass( function(index, class, switch) [, switch ] ):用来返回在匹配的元素集合中的每个元素上用来切换的样式类名的一个函数。接收元素的索引位置和元素旧的样式类作为参数

注意事项:

  1. toggleClass 是一个互斥的逻辑,也就是通过判断对应的元素上是否存在指定的 Class 名,如果有就删除,如果没有就增加;
  2. toggleClass 会保留原有的 Class 名后新增,通过空格隔开;

样式操作 .css()

通过 JavaScript 获取 dom 元素上的 style 属性,我们可以动态的给元素赋予样式属性。在 jQuery 中我们要动态的修改 style 属性我们只要使用 css()方法就可以实现了

.css() 方法:获取元素样式属性的计算值或者设置元素的 CSS 属性

获取:

  1. .css( propertyName ) :获取匹配元素集合中的第一个元素的样式属性的计算值;
  2. .css( propertyNames ):传递一组数组,返回一个对象结果;

设置:

  1.  .css(propertyName, value ):设置 CSS;
  2. .css( propertyName, function ):可以传入一个回调函数,返回取到对应的值进行处理;
  3. .css( properties ):可以传一个对象,同时设置多个样式;

注意事项:

  1. 浏览器属性获取方式不同,在获取某些值的时候都 jQuery 采用统一的处理,比如颜色采用 RBG,尺寸采用 px;
  2. .css()方法支持驼峰写法与大小写混搭的写法,内部做了容错的处理;
  3. 当一个数只被作为值(value)的时候, jQuery 会将其转换为一个字符串,并添在字符串的结尾处添加 px,例如 .css(“width”,50}) 与 .css(“width”,”50px”})一样;

.css()与.addClass()设置样式的区别

对于样式的设置,我们学了 addClass 与 css 方法,那么两者之间有什么区别?

可维护性:

.addClass()的本质是通过定义个 class 类的样式规则,给元素添加一个或多个类。css 方法是通过 JavaScript 大量代码进行改变元素的样式

通过.addClass()我们可以批量的给相同的元素设置统一规则,变动起来比较方便,可以统一修改删除。如果通过.css()方法就需要指定每一个元素是一一的修改,日后维护也要一一的修改,比较麻烦

灵活性:

通过.css()方式可以很容易动态的去改变一个样式的属性,不需要在去繁琐的定义个 class 类的规则。一般来说在不确定开始布局规则,通过动态生成的 HTML 代码结构中,都是通过.css()方法处理的

样式值:

.addClass()本质只是针对 class 的类的增加删除,不能获取到指定样式的属性的值,.css()可以获取到指定的样式值。

样式的优先级:

css 的样式是有优先级的,当外部样式、内部样式和内联样式同一样式规则同时应用于同一个元素的时候,优先级如下:

外部样式 < 内部样式 < 内联样式
  1. .addClass()方法是通过增加 class 名的方式,那么这个样式是在外部文件或者内部样式中先定义好的,等到需要的时候在附加到元素上;
  2. 通过.css()方法处理的是内联样式,直接通过元素的 style 属性附加到元素上的;
通过.css 方法设置的样式属性优先级要高于.addClass 方法

总结:

.addClass 与.css 方法各有利弊,一般是静态的结构,都确定了布局的规则,可以用 addClass 的方法,增加统一的类规则
如果是动态的 HTML 结构,在不确定规则,或者经常变化的情况下,一般多考虑.css()方式

元素的数据存储

html5 dataset 是新的 HTML5 标准,允许你在普通的元素标签里嵌入类似 data-*的属性,来实现一些简单数据的存取。它的数量不受限制,并且也能由 JavaScript 动态修改,也支持 CSS 选择器进行样式设置。这使得 data 属性特别灵活,也非常强大。有了这样的属性我们能够更加有序直观的进行数据预设或存储。那么在不支持 HTML5 标准的浏览器中,我们如何实现数据存取?  jQuery 就提供了一个.data()的方法来处理这个问题

使用 jQuery 初学者一般不是很关心 data 方式,这个方法是 jquery 内部预用的,可以用来做性能优化,比如 sizzle 选择中可以用来缓存部分结果集等等。当然这个也是非常重要的一个 API 了,常常用于我们存放临时的一些数据,因为它是直接跟 DOM 元素对象绑定在一起的

jQuery 提供的存储接口:

jQuery.data( element, key, value )   //静态接口,存数据
jQuery.data( element, key )  //静态接口,取数据   
.data( key, value ) //实例接口,存数据
.data( key ) //实例接口,存数据

2 个方法在使用上存取都是通一个接口,传递元素,键值数据。在 jQuery 的官方文档中,建议用.data()方法来代替。

我们把 DOM 可以看作一个对象,那么我们往对象上是可以存在基本类型,引用类型的数据的,但是这里会引发一个问题,可能会存在循环引用的内存泄漏风险。

通过 jQuery 提供的数据接口,就很好的处理了这个问题了,我们不需要关心它底层是如何实现,只需要按照对应的 data 方法使用就行了。

同样的也提供 2 个对应的删除接口,使用上与 data 方法其实是一致的,只不过是一个是增加一个是删除罢了。

jQuery.removeData( element [, name ] )
.removeData( [name ] )

参考例子:

<h2>jQuery.data()静态方法</h2>
<div class="left">
	<div class="aaron">
		<p>点击看结果</p>
		<p>jQuery.data</p>
	</div>
	<div><span></span></div>
</div>
<h2>.data()实例方法</h2>
<div class="right">
	<div class="aaron">
		<p>点击看结果</p>
		<p>.data</p>
	</div>
	<div><span></span></div>
</div>

CSS 代码:

.left,
.right {
	width: 300px;
	height: 120px;
}

.left div,
.right div {
	width: 100px;
	height: 90px;
	padding: 5px;
	margin: 5px;
	float: left;
	border: 1px solid #ccc;
}

.left div {
	background: #bbffaa;
}

.right div {
	background: yellow;
}

jQuery 代码:

<script type="text/javascript">
	$('.left').click(function() {
		var ele = $(this);
		//通过$.data 方式设置数据
		$.data(ele, "a", "data test")
		$.data(ele, "b", {
			name: "慕课网"
		})
		//通过$.data 方式取出数据
		var reset = $.data(ele, "a") + "</br>" + $.data(ele, "b").name
		ele.find('span').append(reset)
	})
</script>
<script type="text/javascript">
	$('.right').click(function() {
		var ele = $(this);
		//通过.data 方式设置数据
		ele.data("a", "data test")
		ele.data("b", {
			name: "慕课网"
		})
		//通过.data 方式取出数据
		var reset = ele.data("a") + "</br>" + ele.data("b").name
		ele.find('span').append(reset)
	})
</script>

效果展示:

元素的数据存储

「点点赞赏,手留余香」

4

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » [jQuery教程]jQuery的属性与样式(三)

发表回复