jquery attr()无法获取属性值问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jquery attr()无法获取属性值问题相关的知识,希望对你有一定的参考价值。

css里明明已经设置过了:

可还是获取不了:

求指导。

一定是undefined,attr是用来获得或设置标签属性的,不是用来获得CSS属性的。如果你有id是nn1的标签,可以用ww=$("#nn1").css("top");来获得CSS属性。追问

标签属性和css属性怎么区别

追答


$(document).ready(function()
alert($("#nn1").attr("title")); //在div标签中的title就是标签属性,id也是标签属性,也就是出现在标签里的属性;
alert($("#nn1").css("top")); //CSS属性是在样式表中的属性;
);

#nn1
position:relative;
top:30px;


abc

追问

谢谢,懂了。

参考技术A 你有好好学习jQuery吗 attr是获取标签里面的属性
你这个是获取css里面的 要把attr换成css追问

谢谢回答,没学好。

追答

你看看锋利的jquery吧,好懂

追问

好的,多谢推荐好书。

参考技术B ww=$("#nnl").offset().top;
ww=$("#nnl").css("top");追问

谢谢回答。

jQuery属性和样式

1..attr()与.removeAttr():

attr()方法:用来获取和设置元素属性。

attr()的4个表达式:

attr(传入属性名):获取属性的值

attr(属性名, 属性值):设置属性的值

attr(属性名,函数值):设置属性的函数值

attr(attributes):给指定元素设置多个属性值,即:{属性名一: “属性值一” , 属性名二: “属性值二” , … … }

removeAtter()方法:用来为匹配的元素集合中的每个元素中移除一个属性

2..html()和.text():

.html()方法:获取集合中第一个匹配元素的HTML内容 或 设置每一个匹配元素的html内容。

具体有3种用法:

.html() 不传入值,就是获取集合中第一个匹配元素的HTML内容

.html( htmlString )  设置每一个匹配元素的html内容

.html( function(index, oldhtml) ) 用来返回设置HTML内容的一个函数

.text()方法:得到匹配元素集合中每个元素的文本内容结合,包括他们的后代,或设置匹配元素集合中每个元素的文本内容为指定的文本内容。 

具体有3种用法:

.text() 得到匹配元素集合中每个元素的合并文本,包括他们的后代

.text( textString ) 用于设置匹配元素内容的文本

.text( function(index, text) ) 用来返回设置文本内容的一个函数

3..val()

主要是用于处理表单元素的值。

.val()方法:.val()/.val(value)/.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()都可以使用回调函数的返回值来动态的改变多个元素的内容。

4.增加样式.addClass():

.addClass( className ) : 为每个匹配元素所要增加的一个或多个样式名

.addClass( function(index, currentClass) ) : 这个函数返回一个或更多用空格隔开的要增加的样式名

5.删除样式.removeClass():

.removeClass( [className ] ):每个匹配元素移除的一个或多个用空格隔开的样式名

.removeClass( function(index, class) ) : 一个函数,返回一个或多个将要被移除的样式名

6.切换样式.toggleClass():

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

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

7..css() 方法:

获取元素样式属性的计算值或者设置元素的CSS属性。

获取:

.css( propertyName) :获取匹配元素集合中的第一个元素的样式属性的计算值

.css(propertyNames):传递一组数组,返回一个对象结果

设置:

.css(propertyName, value):设置CSS

.css( propertyName, function):可以传入一个回调函数,返回取到对应的值进行处理

.css( properties ):可以传一个对象,同时设置多个样式

注意事项: 

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

css({

            ‘font-size‘        :"15px",

            "background-color" :"#40E0D0",

            "border"           :"1px solid red"

        })//合并设置,通过对象传设置多个样式

css("width",function(index,value){

            value = value.split(‘px‘);//value带单位,先分解

            return (Number(value[0]) + 50) + value[1];//返回一个新的值,在原有的值上,增加50px

        })

以上是关于jquery attr()无法获取属性值问题的主要内容,如果未能解决你的问题,请参考以下文章

jQuery属性与样式

jQuery属性和样式

jquery不能获取多个attr值问题

jquery attr方法和prop方法获取input的checked属性问题

jquery attr方法和prop方法获取input的checked属性问题

jQuery的属性与样式之.attr()与.removeAttr()