如何读写伪类元素的样式?

示例:
<p class="example" data-pseudo="(i'm content.)">Hi, this is a plain-old, sad-looking paragraph tag.</p>
<div id="log"></div>

<style>
.example::before {
    content: 'pseudoElement ';
    color: red;
}
</style>


一、读取,使用 window.getComputedStyle 方法:

<script>
var str = window.getComputedStyle(document.querySelector('.example'), '::before').getPropertyValue('color');

document.querySelector('#log').innerHTML = str;

</script>


二、写(修改)


没有办法。至少没有直接的方法,退而次之,只能通过覆盖样式的途径来达到我们的目的。
譬如:添加一个style元素,并写入新的样式;又或者是给目标元素添加不同的class,以达到控制的效果。

示例:

<style id="pseudoStyle">
</style>


<script>
	document.querySelector('#pseudoStyle').sheet.insertRule(".example::before { color: green;}",0);
	//或者是
	document.querySelector('#pseudoStyle').sheet.addRule('.example::before','color: green');

	//setProperty在这时候,会抛异常:
	try{
		window.getComputedStyle(document.querySelector('.example'), '::before').setProperty('color',"green");
	}catch(e){
		document.querySelector('#log').innerHTML =  e;
	}
</script>


伪类元素,有个属性比较特殊:content。由于它的值可以定义为从元素的dom属性获取,从而可以实现js的直接读写。
例如:

<style>
.example::before {
    content: attr(data-pseudo);
    color: red;
}
</style>


<script>
	document.querySelector('.example').setAttribute("data-pseudo","new content!");
</script>


附录:
1. styleSheet对象的方法、属性和浏览器兼容,参考:http://help.dottoro.com/ljpatulu.php
2. getComputedStyle方法,参考:http://help.dottoro.com/ljscsoax.php , https://developer.mozilla.org/en/docs/Web/API/window.getComputedStyle

你可能感兴趣的:(JavaScript,css)