Vue F05 -- 伪类元素

CSS Query不能通过$(":before")$(dom).find(":before")、document.querySelector(“:before”)来获取:before为元素

伪元素(Pseudo-elements)

为什么不能直接用JS获取伪元素呢?

::before ::after,用于在CSS渲染中向元素是的头部或尾部插入内容,它们不受文档约束,也不影响文档本身,只影响最终样式。这些添加的内容不会出现在DOM中,仅仅是在CSS渲染层中加入

伪元素可以被浏览器渲染,但本身并不是DOM元素。它不存在于文档中,所以JS无法直接操作它

而jQuery的选择器都是基于DOM元素的,因此也并不能直接操作伪元素

介绍

  • ::after
  • ::before
  • ::first-line
  • ::first-letter
  • ::selection
  • ::backdrop

最常用的是::after和::before

具体介绍->https://www.jianshu.com/p/2deb84ad22c8

CSS3中,建议为元素使用两个冒号(::语法),而不是一个冒号(😃,目的是为了区分伪类和伪元素。大多数浏览器都支持着两种表示语法。

只有::selection永远只能以两个冒号开头(:😃

因为IE8只支持单冒号的语法,所以,如果想兼容IE8,保险的做法是使用单冒号

获取伪元素的属性值

window.getComputedStyle()获取伪元素的CSS样式声明对象。然后利用getPropertyValue方法或直接使用键值访问都可以获取对应的属性值

语法:window.getComputedStyle(element[, pseudoElement])

  • 参数如下:
  • element(Object):伪元素的所在的DOM元素;
  • pseudoElement(String):伪元素类型。可选值有:”:after”、”:before”、”:first-line”、”:first-letter”、”:selection”、”:backdrop”;

  1. getPropertyValue()和直接使用键值访问,都可以访问CSSStyleDeclaration Object
    ​ 区别:
  • 对于float属性,如果使用键值访问,不能直接使用getComputedStyle(element,null).float,而应该是cssFloat与styleFloat
  • 直接使用键值访问,则属性的键需要使用驼峰写法,如:style.backgroundColor
  • 使用getPropertyValue()方法未必可以驼峰书写形式(不支持驼峰写法),例如:style.getPropertyValue(“border-top-color”);
  • getPropertyValue()方法在IE9+和其他现代浏览器中都支持;在IE6~8中,可以使用getAttribute()方法来代替
  1. 伪元素默认是"display:inline"。如果没有定义display属性,即使在CSS中显式设置了width的属性值为固定的大小如"100px",但是最后获取的width值仍是"auto"。这是因为行内元素不能自定义设置宽高。解决的办法是给伪元素修改display属性为"block"、“inline-block”

更改伪元素的样式

1、更换class来实现伪元素属性的更改

// CSS代码
.red::before { 
    content: "red"; 
    color: red; 
}
.green::before { 
    content: "green"; 
    color: green;
}

// HTML代码
<div class="red">内容内容内容内容</div>

// jQuery代码
$(".red").removeClass('red').addClass('green');

2、使用CSSStyleSheet的insertRUle来为伪元素修改样式

document.styleSheet[0].addRule('.red::before','color:green');//支持IE document.styleSheets

3、在标签中插入

var style=document.createElement("style");
document.head.appendChild(style);
sheet=style.sheet;
sheet.addRule('.red::before','color:green');//兼容IE浏览器
sheet.insertRule('.red::before{color:green}')//支持非IE的现代浏览器

或使用jQuery

$('<style>.red::before{color:green}</style>').appendTo('heda');

修改伪元素的content的属性值

1、使用CSSStyleSheet的insertRule来为伪元素修改样式

var latestContent="修改过的内容";
var formerContent=window.getComputedStyle($('.red'),'::before').getPropertyValue('content');
document.styleSheets[0].addRule('.red::before','content:"'+latestContent+'"');
ducument.styleSheets[0].insertRule('.red::before{content:"'+latestContent +'"}',0);

2、使用DOM元素的data-*属性来更改content的值

//CSS代码
.red::before{
	content:attr(data-attr);
	color:red;
}
//HTML
<div class="red" data-attr="red">内容内容</div>

//JavaScript代码
$('.red').attr('data-attr','green');

建议

  1. 伪元素的content属性很强大,可以写入各种字符串部分多媒体文件。但是伪元素的内容只存在于CSS渲染树中,并不存在于真实的DOM中。所以为了SEO优化,最好不要在伪元素中包含与文档相关的内容
  2. 修改伪元素的样式,建议使用通过更换class来修改样式的方法。因为其他两种通过插入行内CSSStyleSheet的方式是在JavaScript中插入字符代码,不利于样式与控制分离;而且字符串拼接易出错
  3. 修改伪元素的content属性的值,建议使用利用DOM的data-*属性来更改
    • $('.red').attr('data-attr','green);
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Toreme

随缘喜赞

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值