位置: 编程技术 - 正文

JS控制伪元素的方法汇总(jquery 伪元素)

编辑:rootadmin

推荐整理分享JS控制伪元素的方法汇总(jquery 伪元素),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js获取伪元素并设置点击事件,jquery 伪元素,js获取伪元素并设置点击事件,js伪元素选择器,js控制伪类,js控制伪类,js伪元素选择器,js控制伪元素的作用,内容如对您有帮助,希望把文章链接给更多的朋友!

一. 缘由:

本文源于在OSC社区中,有人提问如何用jq获取伪元素。我第一想法是强大的CSS Query应该可以获取伪元素吧。

然而事实上,CSS Query并不能。即我们不能通过$(“:before”)、$(dom).find(“:before”)或document.querySelector(“:before”)来获取:before伪元素。

为此,我不得不重新了解伪元素(Pseudo-elements)。为什么不能用JS直接获取伪元素呢?

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

事实上, 伪元素可以被浏览器渲染,但本身并不是DOM元素。它不存在于文档中,所以JS无法直接操作它。 而jQuery的选择器都是基于DOM元素的,因此也并不能直接操作伪元素。

那该怎样操作伪元素的样式呢?

为此,我决定好好总结一下JS控制伪元素的方法,方便以后查用。

二. 伪元素有哪些:

首先,先简单说一下伪元素都有哪些。伪元素有六个,分别是 ::after、::before、::first-line、::first-letter、::selection、::backdrop 。

在各大网页中最常用的伪元素,是::after和::before。

这几个伪元素的语意可参考我的另外一篇文章《CSS伪元素选择器 总结》。

在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()方法来代替;

2.伪元素默认是”display: inline”。如果没有定义display属性,即使在CSS中显式设置了width的属性值为固定的大小如”px”,但是最后获取的width值仍是”auto”。这是因为行内元素不能自定义设置宽高。解决办法是给伪元素修改display属性为”block”、”inline-block”或其他。

四. 更改伪元素的样式:

方法1. 更换class来实现伪元素属性值的更改:

JS控制伪元素的方法汇总(jquery 伪元素)

举个栗子:

方法2. 使用CSSStyleSheet的insertRule来为伪元素修改样式:

举个栗子:

方法3. 在 <head> 标签中插入 <style> 的内部样式:

或者用jQuery:

五. 修改伪元素的content的属性值:

方法1. 使用CSSStyleSheet的insertRule来为伪元素修改样式:

方法2. 使用DOM元素的data-*属性来更改content的值:

六. :before和:after伪元素的常见用法总结:

1. 利用content属性,为元素添加内容修饰:

1) 添加字符串:

使用引号包括一段字符串,将会向元素内容中添加字符串。栗子:

2) 使用attr()方法,调用当前元素的属性的值:

栗子:

3)使用url()方法,引用多媒体文件:

栗子:

4) 使用counter()方法,调用计时器:

栗子:

2. 清除浮动:

3. 特效妙用:

4. 特殊形状的实现:

举个栗子:(譬如对话气泡)

:before 和 :after 伪元素结合更多CSS3强大的特性,还可完成非常多有趣的特效和 hack ,这里权当抛砖引玉。

六. 一点小小建议:

伪元素的content属性很强大,可以写入各种字符串和部分多媒体文件。但是伪元素的内容只存在于CSS渲染树中,并不存在于真实的DOM中。所以为了SEO优化,最好不要在伪元素中包含与文档相关的内容。

修改伪元素的样式,建议使用通过更换class来修改样式的方法。因为其他两种通过插入行内CSSStyleSheet的方式是在JavaScript中插入字符代码,不利于样式与控制分离;而且字符串拼接易出错。

修改伪元素的content属性的值,建议使用利用DOM的data-*属性来更改。

以上所述是小编给大家介绍的JS控制伪元素的方法汇总,希望对大家有所帮助!

JS密码生成与强度检测完整实例(附demo源码下载) 本文实例讲述了JS密码生成与强度检测的方法。分享给大家供大家参考,具体如下:1.生成强密码截图如下:相关代码如下:functiongetPwd(n){vars='';while(n--)s

JS动态改变浏览器标题的方法 本文实例讲述了JS动态改变浏览器标题的方法。分享给大家供大家参考,具体如下:!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""

JavaScript中实现无缝滚动、分享到侧边栏实例代码 废话不多说,直接给大家贴代码了,代码解决一起问题!下面一段代码给大家介绍js无缝滚动实例代码:代码如下所示:!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Tran

标签: jquery 伪元素

本文链接地址:https://www.jiuchutong.com/biancheng/373401.html 转载请保留说明!

上一篇:JS实现把鼠标放到链接上出现滚动文字的方法(js鼠标移入事件)

下一篇:JS密码生成与强度检测完整实例(附demo源码下载)(js中密码由字母和数字组成,长度为4-20)

  • 递延所得税资产会计处理全过程
  • 农业企业免哪些税款
  • 申报所得税季初资产总额怎么填?
  • 其他应收款财务报表取数
  • 理财收益交增值税
  • 弥补上年度亏损
  • 母子公司借款要交什么税
  • 广告策划费会计分录
  • 现金流管理模式
  • 期间费用如何设置项目核算
  • 汇算清缴职工福利支出
  • 劳务外包要通过应付职工薪酬吗
  • 工程公司后期维保费用如何入账?
  • 应收而未收的装修款如何做账务处理?
  • 企业债务重组的案例
  • 合伙企业可以弥补以前年度亏损吗
  • 个体户销售蔬菜免增值税吗
  • 给个人的返利如何交税
  • 增值税申报金额含税吗
  • 税务局查账征收转为核定征收之程序
  • 已抵扣发票如何查询开票明细
  • 国税地税合并后叫什么名称
  • 长期驻扎外地的员工
  • 本月暂估入库,下月
  • 多交增值税如何做账
  • 废品损失的计算公式
  • 支付网银年费计入什么科目
  • 在王者荣耀中怎么找个妹子
  • 华为鸿蒙os2.0发布
  • 其他权益工具投资公允价值变动怎么计算
  • 总资产净利率和权益乘数之间的关系
  • 印花税减半征收优惠政策2023
  • 当月制造费用转生产成本
  • 辞退补偿入账
  • 商家说补发什么意思
  • php oci
  • 光纤布线有什么作用
  • key是什么文档
  • 权益法投资收益在年末确认
  • Win10 21H1 Build 19043.1200(KB5005101)预览版更新了哪些内容(附更新日志)
  • fssm32.exe是什么进程 有什么作用 fssm32进程查询
  • PHP:connection_aborted()的用法_misc函数
  • 普通增值税发票会计科目怎么写?
  • Yii2 rbac权限控制操作步骤实例教程
  • 库存股属于什么
  • vue ref获取元素高度
  • react reducer详解
  • php搜索代码
  • 电子税务局已申报的财务报表怎么修改
  • 消防工程材料费用占比
  • 投资公司如何注册勘察设计工程师证书
  • 土地使用税的征税范围有哪些
  • java事件处理机制三个重要概念
  • vuex 3
  • 计提应收账款坏账准备属于谨慎性吗
  • 增值税普票税额可以抵扣税吗
  • 工商年报纳税总额包括滞纳金吗
  • 开的票比实际支付的多,账务怎么处理
  • 销售退回如何做账务处理
  • 实收资本多少年到账
  • 对公帐户资金转入个人帐户规定
  • 用友软件中冲销凭证在哪
  • 新办企业是不是企业
  • 个体工商户是否要交税
  • 国际贸易单证有什么制单要求
  • MySql 5.6.14 winx64配置方法(免安装版)
  • centos7.4
  • win8 net framework
  • Win10系统安装包
  • 深入了解XP中“最后一次正确配置”功能
  • 苹果mac系统如何升级最新版本
  • OS X Yosemite系统怎么样 OS X Yosemite功能介绍
  • linux vmware命令行
  • 自动化测试读写题答案
  • linux随机数生成1到100
  • 实用的批处理
  • 示例代码
  • jquery22插件网
  • 报考国税
  • 进口小麦关税税率是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设