如何用js控制css伪类after

html-css0187

如何用js控制css伪类after,第1张

用js控制css伪类after:只能通过添加样式,然后通过这个样式的伪类来控制吧。。没法直接改。

比如:

html:

<p>瓦赫塔 阿热 有 doing</p>

css:

p:after{

content:''

position:absolute

background-color:green

width:20px

height:6px

}

js:

var css=function(t,s){

s=document.createElement('style')

s.innerText=t

document.body.appendChlild(s)

}

document.onclick=function(){

css('p:after{background-color:red}')

}

【浮动产生负作用 】

1、背景不能显示

由于浮动产生,如果对父级设置了(CSS background背景)CSS背景颜色或CSS背景图片,而父级不能被撑开,所以导致CSS背景不能显示。

2、边框不能撑开

如上图中,如果父级设置了CSS边框属性(css border),由于子级里使用了float属性,产生浮动,父级不能被撑开,导致边框不能随内容而被撑开。

3、margin padding设置值不能正确显示

由于浮动导致父级子级之间设置了css padding、css margin属性的值不能正确表达。特别是上下边的padding和margin不能正确显示。

【css解决浮动,清除浮动方法】

方法一:

<div class="content">

    <div class="fl"></div>

    <div class="fr"></div>

    <div class="clear"></div>

</div>

.clear {clear:bothheight:0font-size:0line-height:0overflow:hidden}

可以不用对父级设置高度 也无需技术父级高度,方便适用,但会多加CSS和HTML标签。

方法二:对父级设置适合CSS高度

方法三:父级div定义 overflow:hidden

对父级CSS选择器加overflow:hidden样式,可以清除父级内使用float产生浮动。优点是可以很少CSS代码即可解决浮动产生。

方法四:

.cle:after, .clearfix:after, .clear_f:after, .cle_float:after{visibility:hiddendisplay:blockfont-size:0content:'\20'clear:bothheight:0}

.cle, .clearfix, .clear_f, .cle_float{*zoom:1}

在父级加上一个class