jquery获取对象的css属性值的时候,就算我们没有给这个对象设置过css属性值,这些值也会存在,只不过有些是默认值。下面我们来输出一个div的css属性值,原始代码如下
<!DOCTYPE html>
<html>
<head>
<title>DIV_TEST</title>
<meta charset="utf-8"/>
<style type="text/css">
#top1{
}
</style>
</head>
<body>
<div id="top1">
<u>你好我是某某某</u>
</div>
<script src="jquery-3.2.1.min.js" ></script>
<script>
$(document).ready(function(){
console.log("float的值是:"+$("#top1").css("float"));
console.log("height的值是:"+$("#top1").css("height"));
console.log("overflow的值是:"+$("#top1").css("overflow"));
console.log("color的值是:"+$("#top1").css("color"));
console.log("big的值是:"+$("#top1").css("big"));
});
</script>
</body>
</html>
结果如下
![](https://video.ask-data.xyz/img.php?b=https://iknow-pic.cdn.bcebos.com/f9dcd100baa1cd114760c275b212c8fcc2ce2d94?x-bce-process=image%2Fresize%2Cm_lfit%2Cw_600%2Ch_800%2Climit_1%2Fquality%2Cq_85%2Fformat%2Cf_auto)
可以看到我们没有设置过div的css属性,除了高度以外剩下的只要存在这个css属性的都是默认值,唯一不同的是最后一个big属性,我们知道这个属性不是css的属性,因此我们判断有没有某个属性的时候可以通过这个方式判断
$(document).ready(function(){
console.log("是否存在big属性:"+testHasCss($("#top1"),"big"));
console.log("是否存在color属性:"+testHasCss($("#top1"),"color"));
console.log("是否存在display属性:"+testHasCss($("#top1"),"display"));
console.log("是否存在gogo属性:"+testHasCss($("#top1"),"gogo"));
});
var testHasCss = function(obj,cssStr){
if((obj).css(cssStr) === undefined){
return false;
}else{
return true;
}
}
结果如下
![](https://video.ask-data.xyz/img.php?b=https://iknow-pic.cdn.bcebos.com/6d81800a19d8bc3ea7b2bf9f898ba61ea8d34528?x-bce-process=image%2Fresize%2Cm_lfit%2Cw_600%2Ch_800%2Climit_1%2Fquality%2Cq_85%2Fformat%2Cf_auto)