在前端开发中我们会经常用到伪元素,有时候需要通过js来修改伪元素的样式,那么有哪几种方式来修改伪元素的样式呢?...伪元素用来做什么呢? CSS 伪元素用于向某些选择器设置特殊效果。...伪元素有哪些特点呢? 1、通过伪元素添加的内容不能被选中 2、伪元素添加的内容不会出现在DOM中,仅仅是在CSS渲染层中加入,所以不能直接通过js来获取 3、只能通过修改样式表的方式来修改伪元素。...这就绕到了我们开头的问题,首先看第一种方式,修改class类名来修改伪元素的样式: // CSS代码 .red::before { content: "red"; color: red; } .green...以上便是通过js修改伪元素样式的方法,希望对你有所帮助。
操作样式只能操作元素的行内样式 二、style的设置 原生js可以单独设置元素的行内样式。...原生js操作的都是行内样式,那么怎么获取非行内样式呢?...(element[,pseudo-element]); 或者window.getComputedStyle(element[,pseudo-element]); 首先是有两个参数,元素和伪类。...第二个参数不是必须的,当不查询伪类元素的时候可以忽略或者传入 null。 2. 返回值 getComputedStyle 返回的对象是 CSSStyleDeclaration 类型的对象。...而不同点就是: element.style 读取的只是元素的内联样式,即写在元素的 style 属性上的样式;而 getComputedStyle 读取的样式是最终样式,包括了内联样式、嵌入样式和外部样式
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/107349.html原文链接:https://javaforall.cn
本期介绍 本期主要介绍CSS样式表进阶之伪元素 文章目录 1. 简述及示例 2. 功能实现 2.1 样式 API 2.2 代码实现 3. 总结 1. ...示例: 可以在某个元素内容之前加入 样式和信息 可以在某个元素内容之后加入 样式和信息 可以单独为某个元素内容的第一个字符添加样式 可以单独为某个元素内容的第一行添加样式 在以后的学习开发中...,我们还会接触到 a 标签等特殊元素的伪元素设置。...功能实现 2.1 样式 API 伪元素书写格式: 选择器名 : 伪元素 例如: div:before 常见的伪元素: 2.2 代码实现 :before 代码 :after...总结 伪元素 用于某个元素上,修饰某个元素的状态或一部分,多用于细致化样式调整。
:first-letter 伪元素的样式将应用于元素文本的第一个字(母)。 :first-line 伪元素的样式将应用于元素文本的第一行。 :before 在元素内容的最前面添加新内容。...:after 在元素内容的最后面添加新内容。...伪元素和伪类的区别: 与伪类针对特殊状态的元素不同的是,伪元素是对元素中的特定内容进行操作,设计伪元素的目的就是去选取诸如元素内容第一个字(母)、第一行,选取某些内容前面或后面这种普通的选择器无法完成的工作...它控制的内容实际上和元素是相同的,但是它本身只是基于元素的抽象,并不存在于文档中,所以叫伪元素。
习惯了jquery的同学应该都知道获取元素样式的方式可以直接写成(obj).css(style);更方便的获取高度宽度等一些样式可以直接使用(obj).height()和 一、 getComputedStyle...为什么要用这个属性呢,是因为通过document.getElementById(element).style.xxx可以获取元素的样式信息但是对于通过class属性引用的外部样式表就获取不到了。...使用方法如下 var style = window.getComputedStyle("元素", "伪类"); 例如 var dom = document.getElementById("test"),...但是getComputedStyle属性是只读的属性,只能读属性,不能设置,但是他可以获取到元素的最终样式信息。...不过,currentStyle属性貌似不支持伪类样式获取,这是与getComputedStyle方法的差异,也是jQuery css()方法无法体现的一点。
下面分别对伪类和伪元素进行解释: 伪类用于当已有元素处于的某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。...虽然它和普通的css类相似,可以为已有的元素添加样式,但是它只有处于dom树无法描述的状态下才能为元素添加样式,所以将其称为伪类。 伪元素用于创建一些不在文档树中的元素,并为其添加样式。... 如果想要给该段落的第一个字母添加样式,可以在第一个字母中包裹一个元素,并设置该span元素的样式: HTML: Hello World... CSS: .first { font-size: 5em; } 如果不创建一个元素,我们可以通过设置的:first-letter伪元素来为其添加样式。...这个时候,看起来好像是创建了一个虚拟的元素并添加了样式,但实际上文档树中并不存在这个元素。
效果如下: www.w3h5.com 查看代码发现标签上有一个:hover,鼠标划入时添加一个:after伪类,给这个伪类设置背景渐变、绝对定位和高度,实现了这种“炫酷”的效果。...html部分代码: www.w3h5.com 样式部分代码: code{ display: inline-block; ...声明:本文由w3h5原创,转载请注明出处:《利用css中的伪类 给元素设置特殊样式效果》 https://www.w3h5.com/post/51.html
伪类 伪类用于当已有元素处于的某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。比如说,当用户悬停在指定的元素时,我们可以通过:hover来描述这个元素的状态。...虽然它和普通的css类相似,可以为已有的元素添加样式,但是它只有处于dom树无法描述的状态下才能为元素添加样式,所以将其称为伪类。 状态性伪类 是基于元素当前状态进行选择的。...在与用户的交互过程中元素的状态是动态变化的,因此该元素会根据其状态呈现不同的样式。当元素处于某状态时会呈现该样式,而进入另一状态后,该样式也会失去。...:disabled 匹配禁用的表单元素 :enabled 匹配没有设置disabled属性的表单元素 :valid 匹配条件验证正确的表单元素 伪元素 用于创建一些不在文档树中的元素,并为其添加样式。...比如说,我们可以通过::before来在一个元素前增加一些文本,并为这些文本添加样式。 CSS3规范中要求使用单冒号:用于CSS3伪类,双冒号::用于 CSS3伪元素,目的是区分伪类和伪元素。
下面分别对伪类和伪元素进行解释: 伪类用于当已有元素处于的某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。...虽然它和普通的css类相似,可以为已有的元素添加样式,但是它只有处于dom树无法描述的状态下才能为元素添加样式,所以将其称为伪类。 伪元素用于创建一些不在文档树中的元素,并为其添加样式。... 如果想要给该段落的第一个字母添加样式,可以在第一个字母中包裹一个元素,并设置该span元素的样式: HTML: Hello... CSS: .first { font-size: 5em; } 如果不创建一个元素,我们可以通过设置的:first-letter伪元素来为其添加样式。...这个时候,看起来好像是创建了一个虚拟的元素并添加了样式,但实际上文档树中并不存在这个元素。
利用伪元素:after清除浮动 让页面呈现多列布局时经常会使用 float:left/right ,可是浮动布局会导致父元素的高度为0(未设置高度的情况下),不会根据子元素的高度而变化,另外,后面不需要浮动想在下一行显示的标签出现在浮动元素的后面...所以我们在使用浮动进行布局的时候会需要一个块级元素(行内元素无效)来设置 clear 属性,如果浮动元素下方本来就有元素,那我们可以直接对该元素设置 clear:both ,若没有其他元素需要展示,我们往往会写一个空白标签来清除浮动... 但是这样无疑会增加浏览器的渲染负担,所以考虑使用伪元素 :after 来代替这个空白标签,因为清除浮动需要在浮动元素后面,所以不可以使用...:before ,对 :after 设置 content:"" ,并使其 display:block 成为块级元素后 clear:both 来清除浮动: #content:after{content:"
什么是伪元素 伪元素表示了某个元素的子元素。这个子元素虽然在逻辑上存在,但却并不实际存在于文档树中。 因为伪元素并不在文档树中,所以通过JS,也抓取不到伪元素,也不能给它绑事件。...语法 伪元素以::开头。 在CSS1和CSS2中,伪元素和伪类一样,都是用:开头。但在CSS3中,伪元素以::开头,用以和伪类进行区分。 IE8不支持::。因此如果要兼容IE8,只能用:。...对::first-line只能使用下面的样式 Font: font, font-style, font-variant, font-weight, font-size, line-height和font-family...什么时候用伪元素 HTML 标签的目的,就是为了展示内容信息。非内容信息要使用伪元素。 具体的使用场景是图标和清除浮动。 所谓的非内容信息,指的是一些对内容进行修饰的信息。...相关文章 CSS伪元素的一些坑
今天做了一个有关js如何绑定动态修改伪类的content的内容,运用到的有( :before 和 :after 伪元素、CSS content 属性、data-* H5新属性、js)等技术。...; 3)在样式里添加box元素的:before伪元素和:after 伪元素; 4):before伪元素和:after 伪元素里各自添加content属性; 5)content 和 attr...找到添加的 [data-content-before=":before"]和[ data-content-after=":after"]属性的value,有了value值,这就可以进行动态修改 before伪元素和...:after 伪元素里的content值; 以此现在做一个笔记以便以后使用,Hope to help you....'; box.attributes[2].value = ':after伪元素';
---- 本文简介 你是否在使用 Fabric.js 时希望能在选中元素后自定义元素样式或选框(控制角和辅助线)的样式? 如果是的话,可以放心往下读。...本文将手把脚和你一起过一遍 Fabric.js 在对象元素选中后常用的样式设置。 我将对象元素选中后的设置分成3类进行讲解: 控制角 辅助边 其他样式 状态 准备工作 创建一个画布和一个圆形。...本文要介绍 Fabric.js 的背景色有2种。一种是元素自身的背景色,另一种是选中后的背景色。 在 Fabric.js 里,背景色和填充色是两回事。...代码仓库 ⭐ Fabric.js 元素选中状态的事件与样式 推荐阅读 我最近在整理 Fabric.js 常用方法,有兴趣的可以看看 《Fabric.js中文教程》 《Fabric.js 拖放元素进画布》...《Fabric.js 限制边框宽度缩放》 《Fabric.js 监听元素相交(重叠)》 《Fabric.js 橡皮擦的用法(包含恢复功能)》 《Fabric.js 喷雾笔刷 从入门到放肆》 《Fabric.js
伪类的效果可以通过添加一个实际的类来达到,而伪元素的效果则需要通过添加一个实际的元素才能达到,这也是为什么他们一个称为伪类,一个称为伪元素的原因。...伪类的种类 伪元素的种类 区别 这里用伪类 :first-child 和伪元素 :first-letter 来进行比较。...,然后定义这个类的样式。...那么我们接着看看为元素: p:first-letter {color: red}I am stephen lee.... 总结 伪元素和伪类之所以这么容易混淆,是因为他们的效果类似而且写法相仿,但实际上 css3 为了区分两者,已经明确规定了伪类用一个冒号来表示,而伪元素则用两个冒号来表示。
伪元素技巧 在 CSS 伪元素基本用法一文中讲述了伪元素的基础功能,本章学习一些进阶功能,看看伪元素能实现哪些方便好用的功能。...; padding: 5px; } .inner { float: left; width: 80px; height: 80px; border: 1px solid; } 使用伪元素清除浮动的办法...input:checked { counter-increment: site; } .count:before { content: counter(site); } 自制 checked 样式...{ background: green; border: 2px solid green; color: #fff; content: "\2714"; } 最后 在网上还有很多关于伪元素的用法...,非常有趣,既能减少 DOM 元素数量,还能用 CSS 实现一部分 JS 的功能,非常酷炫,后面见到有趣的用法会不断记录。
背景 写了这么多年代码,对CSS中的伪类和伪元素竟然没有细致的进行过学习总结,由此可见在实际代码开发中,用的也确实不多,也就用过一些:first-child,:hover之类的吧,其它的连before...什么的都没用过,于是迫切需要大于伪元素与伪类进行一个系统整体的学习。...伪类和伪元素 伪类:是以一个冒号作为前缀,被添加到选择器的末尾,当你希望在特定状态下(:hover)才被呈现到指定元素时,可以往元素的选择器后面加上伪类。...伪元素:用于创建一些不在文档树中的元素,并为其添加样式。比如::before是指得元素前添加文本,且为文本添加样式,虽然用户可以看到这些文本,但文本实际不在DOM结构中。...常用的伪类和伪元素 伪类可以从状态类伪类、结构类伪类、其它伪类和表单相关伪类进行分类。
2.伪类和伪元素的概念 2.1 伪类: 伪类用于当已有元素处于某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。...虽然它和普通的 CSS 类相似,可以为已有的元素添加样式,但是它只有处于 DOM 树无法描述的状态下才能为元素添加样式,所以将其称为伪类。...2.2 伪元素 伪元素用于创建一些不在文档树中的元素,并为其添加样式。 例如,我们可以通过 :before 来在一个元素前增加一些文本,并为这些文本添加样式。...3.伪类列举 伪类和伪元素-1.png 3.1 状态伪类 状态伪类是基于元素当前状态进行选择的。在与用户的交互过程中元素的状态是动态变化的,因此该元素会根据其状态呈现不同的样式。...当元素处于某状态时会呈现该样式,而进入另一状态后,该样式就会失去。状态伪类的顺序很重要,顺序错误可能会导致没有效果。
伪元素 伪元素是一个附加至选择器末的关键词,允许你对被选择元素的特定部分修改样式。 下例中的 ::first-line 伪元素可改变段落首行文字的样式。 /* 每一个 元素的第一行。...*/ p::first-line { color: blue; text-transform: uppercase; } 伪类连同伪元素一起,他们允许你不仅仅是根据文档 DOM 树中的内容对元素应用样式...分类 伪类 ? 伪元素 ?... 如果想要给该段落的第一个字母添加样式,可以在第一个字母中包裹一个元素,并设置该span元素的样式: Hello World, and... .first { font-size: 5em; } 如果不创建一个元素,我们可以通过设置的:first-letter伪元素来为其添加样式。
熟悉前端的人都会听过css的伪类与伪元素,然而大多数的人都会将这两者混淆(包括我)。那今天就让我们来看看伪类和伪元素的区别吧!...伪类与伪元素 先说一说为什么css要引入伪元素和伪类,以下是css2.1 Selectors章节中对伪类与伪元素的描述: CSS introduces the concepts of pseudo-elements...下面分别对伪类和伪元素进行解释: 伪类用于当已有元素处于的某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。...虽然它和普通的css类相似,可以为已有的元素添加样式,但是它只有处于dom树无法描述的状态下才能为元素添加样式,所以将其称为伪类。 伪元素用于创建一些不在文档树中的元素,并为其添加样式。...比如说,我们可以通过:before来在一个元素前增加一些文本,并为这些文本添加样式。虽然用户可以看到这些文本,但是这些文本实际上不在文档树中。
领取专属 10元无门槛券
手把手带您无忧上云