个人学习javascript代码笔记2019/6/30(使用DOM操作CSS、读取元素的样式)

初始:                                                                           “点我一下”按钮:

                              

“点我一下2”按钮:

如果从初始直接点击“点我一下2”,显示空白:

使用DOM操作CSS:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			
			#box1{
				width: 100px;
				height: 100px;
				background-color: red;
			}
			
		</style>
		
		<script type="text/javascript">
			
			window.onload = function(){
				
				/*
				 * 点击按钮以后,修改box1的大小
				 */
				//获取box1
				var box1 = document.getElementById("box1");
				//为按钮绑定单击响应函数
				var btn01 = document.getElementById("btn01");
				btn01.onclick = function(){
					
					//修改box1的宽度
					/*
					 * 通过JS修改元素的样式:
					 * 	语法:元素.style.样式名 = 样式值
					 * 
					 * 注意:如果CSS的样式名中含有-,
					 * 		这种名称在JS中是不合法的比如background-color
					 * 		需要将这种样式名修改为驼峰命名法,
					 * 		去掉-,然后将-后的字母大写
					 * 
					 * 我们通过style属性设置的样式都是内联样式,
					 * 	而内联样式有较高的优先级,所以通过JS修改的样式往往会立即显示
					 * 
					 * 但是如果在样式中写了!important,则此时样式会有最高的优先级,
					 * 	即使通过JS也不能覆盖该样式,此时将会导致JS修改样式失效
					 * 	所以尽量不要为样式添加!important
					 * 
					 * 
					 * 
					 */
					box1.style.width = "300px";
					box1.style.height = "300px";
					box1.style.backgroundColor = "yellow";
					
				};
				
				
				//点击按钮2以后,读取元素的样式
				var btn02 = document.getElementById("btn02");
				btn02.onclick = function(){
					//读取box1的样式
					/*
					 * 	语法:元素.style.样式名
					 * 
					 * 通过style属性设置和读取的都是内联样式
					 * 	无法读取样式表中的样式
					 */
					//alert(box1.style.height);
					alert(box1.style.width);
				};
			};
			
			
		</script>
	</head>
	<body>
		
		<button id="btn01">点我一下</button>
		<button id="btn02">点我一下2</button>
		
		<br /><br />
		
		<div id="box1"></div>
		
	</body>
</html>

       注意:如果CSS的样式名中含有-,这种名称在JS中是不合法的比如background-color需要将这种样式名修改为驼峰命名法,去掉-,然后将-后的字母大写。

       我们通过style属性设置的样式都是内联样式,而内联样式有较高的优先级,所以通过JS修改的样式往往会立即显示,但是如果在样式中写了!important,则此时样式会有最高的优先级,即使通过JS也不能覆盖该样式,此时将会导致JS修改样式失效,所以尽量不要为样式添加!important。

读取box1的样式。语法:元素.style.样式名,通过style属性设置和读取的都是内联样式(行内样式<p style="color:orange;font-size:18px">在HTML中如何使用css样式</p>),无法读取样式表中的样式(内嵌样式和外部链入样式<style type="text/css"> ....css样式代码 </style> 和<link href="文件名.css" type="text/css" rel="stylesheet"/>)。比如设置内嵌样式,元素.style.样式名这种方式无法读取。

读取元素样式:

<!DOCTYPE html>
<html>

	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			#box1 {
				width: 100px;
				height: 100px;
				background-color: yellow;
			}
		</style>

		<script type="text/javascript">

			window.onload = function () {

				//点击按钮以后读取box1的样式
				var box1 = document.getElementById("box1");
				var btn01 = document.getElementById("btn01");
				btn01.onclick = function () {
					//读取box1的宽度
					//alert(box1.style.width);

					/*
					 * 获取元素的当前显示的样式
					 * 	语法:元素.currentStyle.样式名
					 * 它可以用来读取当前元素正在显示的样式
					 * 	如果当前元素没有设置该样式,则获取它的默认值
					 * 
					 * currentStyle只有IE浏览器支持,其他的浏览器都不支持
					 */

					//alert(box1.currentStyle.width);
					//box1.currentStyle.width = "200px";
					//alert(box1.currentStyle.backgroundColor);

					/*
					 * 在其他浏览器中可以使用
					 * 		getComputedStyle()这个方法来获取元素当前的样式
					 * 		这个方法是window的方法,可以直接使用
					 * 需要两个参数
					 * 		第一个:要获取样式的元素
					 * 		第二个:可以传递一个伪元素,一般都传null
					 * 
					 * 该方法会返回一个对象,对象中封装了当前元素对应的样式
					 * 	可以通过对象.样式名来读取样式
					 * 	如果获取的样式没有设置,则会获取到真实的值,而不是默认值
					 * 	比如:没有设置width,它不会获取到auto,而是一个长度
					 * 
					 * 但是该方法不支持IE8及以下的浏览器
					 * 
					 * 通过currentStyle和getComputedStyle()读取到的样式都是只读的,
					 * 	不能修改,如果要修改必须通过style属性
					 */
					//var obj = getComputedStyle(box1,null);

					/*alert(getComputedStyle(box1,null).width);*/
					//正常浏览器的方式
					//alert(getComputedStyle(box1,null).backgroundColor);

					//IE8的方式
					//alert(box1.currentStyle.backgroundColor);

					//alert(getStyle(box1,"width"));
					// 既兼容IE8以下,又支持其他所有浏览器的自定义方法如下
					var w = getStyle(box1, "width");
					alert(w);


				};

			};

			/*
			 * 定义一个函数,用来获取指定元素的当前的样式
			 * 参数:
			 * 		obj 要获取样式的元素
			 * 		name 要获取的样式名
			 */

			function getStyle(obj, name) {
                // 必须用window.getComputedStyle而不是getComputedStyle
                // getComputedStyle会找全局变量,但是window.getComputedStyle会直接找全局属性,避免在IE的报错
				if (window.getComputedStyle) { // 判断浏览器中是否具有getComputedStyle方法,而不用判断浏览器类型版本
					//正常浏览器的方式,具有getComputedStyle()方法
					return getComputedStyle(obj, null)[name];
				} else {
					//IE8的方式,没有getComputedStyle()方法
					return obj.currentStyle[name];
				}

				//return window.getComputedStyle?getComputedStyle(obj , null)[name]:obj.currentStyle[name];

			}


		</script>
	</head>

	<body>
		<button id="btn01">点我一下</button>
		<br /><br />
		<div id="box1"></div>
	</body>

</html>

在其他浏览器中可以使用getComputedStyle()这个方法来获取元素当前的样式,这个方法是window的方法,可以直接使用。

getComputedStyle()需要两个参数:
                     *         第一个:要获取样式的元素
                     *         第二个:可以传递一个伪元素,一般都传null
该方法会返回一个对象,对象中封装了当前元素对应的样式。可以通过对象.样式名来读取样式。 如果获取的样式没有设置,则会获取到真实的值,而不是默认值。比如:没有设置width,它不会获取到auto(currentStyle在IE显示auto),而是一个长度。但是该方法不支持IE8及以下的浏览器。通过currentStyle和getComputedStyle()读取到的样式都是只读的,不能修改,如果要修改必须通过style属性。

 ==============Talk is cheap, show me the code==============

发布了209 篇原创文章 · 获赞 344 · 访问量 89万+

猜你喜欢

转载自blog.csdn.net/qq_34115899/article/details/94305822
今日推荐