博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js如何控制css伪元素内容(before,after)
阅读量:6077 次
发布时间:2019-06-20

本文共 777 字,大约阅读时间需要 2 分钟。

原文:

js如何控制css伪元素(before,after)

@(CSS 笔记)[伪元素|css3]

曾经遇到的问题,在对抗UC浏览器屏蔽需要把内容输出到css 伪元素中输出。有个疑问如何用js控制它。于是在segmentfault提问,如下是对问题的整理:

简单粗暴的方式:

简单粗暴的方式,直接在html中添加样式覆盖掉之前样式规则

正文内容

进化版

这样写了功能实现了,优雅欠佳,作为进化版,其实就是用class名来重写样式,

p:after{content:'我是后缀'}p.change{content:'我是修改过的后缀'}

只要在需要的时候,给p标签添加change这个class就可以实现替换的目的。原理和第一个没什么区别。这样写的好处是,改变起来更优雅灵活,用class做了个钩子。

再进化版

上个版本已经解决了切换的问题,如果有更多可以不断的切换class,但是想下这种方式也还是有点笨重,因为可能要写很多css,如果是想换的内容是不确定的,需要用变量来处理呢?这时候,可能会想到用 第一种方法就可以了,但是第一种方式真的不是很优雅。还有什么方式呢?

在css中,伪元素的content是能读取到data属性的。
也就是说我们可以这样写css

p:after {	content: attr(data-content);}

在进化版是第二版的变种,

css文件

p.change:after {	content: attr(data-content);}

js文件

$(this).addClass('change').attr('data-content', content);

这样你就可以随意改动了。

不是终极版的终极版

最后一种方法是由提供方法很hack了,遍历了所有的css文档,找到伪元素,然后更改,有兴趣的同学可以尝试下

转载地址:http://tqagx.baihongyu.com/

你可能感兴趣的文章
H5端调起百度地图、腾讯地图app
查看>>
yum安装软件报错Segmentation fault处理
查看>>
程序员45个好习惯
查看>>
关于保留页面状态的一些总结
查看>>
3 ways of including JavaScript in HTML
查看>>
js的Prototype属性 解释及常用方法
查看>>
EntityFramework 启用迁移 Enable-Migrations 报异常 "No context type was found in the assembly"
查看>>
SCC模板
查看>>
专题二经典问题解析_13
查看>>
和小猪一起搞微信公众号开发—创建自定义菜单
查看>>
C# 检测网络链接
查看>>
WPF 让Enter键按下时默认为某按钮(Button)事件
查看>>
Nginx下配置codeigniter框架
查看>>
git学习笔记(1)
查看>>
面试题3
查看>>
lucene全文检索技术
查看>>
java某课程安排
查看>>
Algs4-2.2.16自然的归并排序
查看>>
链表的基本操作(Basic Operations on a Linked List)
查看>>
Codeforces Round #195 (Div. 2) 解题报告
查看>>