markdown样式覆盖的解决方案

背景

        最近公司在搞的ai项目中遇到了一个场景,公司一个新的ai项目在最开始搭建项目的直接引用了reset.css,项目开发到一半需要引用react-markdown插件展示gpt返回的内容,但是渲染的时候发现例如h1、h2、li、ui标签等等的默认样式由于reset的原因直接失效了然而项目开发已经进行到一半了不可能直接将reset.css去掉。

解决

        查了各种插件相关的资料发现想通过插件本身的参数来解决是不太可能的,于是转念一想还是直接从css入手。

1.给节点加上class名

import Markdown from 'react-markdown'export default () => {return <Markdown className="editor"># 标题h1</Markdown>
}

2.reset.css样式处理

*:not(.editor) {line-height: 1rem;margin: 0;padding: 0;...
}.editor {line-height: 1.5rem;
}.editor * {line-height: inherit;margin: revert;padding: revert;...
}

1.其中样式重置中的not(.editor)i排除选中文档流中class名为editor的节点但是这里不包括.editor下的子节点。
2.下面的.editor *是给.editor下的子节点进行revert默认样式还原
3.中间遇到line-height属性比较特殊直接revert无法直接还原样式因此我在.editor节点上直接设置line-height样式然后在子节点中通过inherit去继承父元素的样式

总结

        css还是有蛮多可玩性的,包括现在的css-in-js、unocss、.css文件、classNames、styledComponent等形式,虽然不可能完全剔除css代码,但是发展方向一直都是在精简css代码量在项目中的比重,例如我们这次就大量的采用unocss的方式配合少量的css-in-js和styledComponent大大降低了css代码在项目中的占比提高了代码的可读性。
        好的东西最终是会被慢慢接受的,最开始的时候团队里面都不适应unocss的css方式但是在这次的项目开发下来也都是欣然的接受了unocss。

弱者是没有资格谈正义的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/49829.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ipad可以用别的品牌的手写笔吗?开学平价电容笔推荐

开学需要买什么呢&#xff1f;随着科技的不断进步&#xff0c;各种类型的iPad电容笔应运而生。一支好的电容笔&#xff0c;不仅能大大提高我们的工作效率&#xff0c;而且能大大提高我们的生产力。平替的这款电容笔&#xff0c;不管是在技术上&#xff0c;还是在品质上&#xf…

关于路由器和DNS解析的一些新理解

其实我本人对于交换机和路由器这些网络硬件是比较感兴趣的&#xff0c;也在一点一点的学习相关知识&#xff0c;每次解决一个问题&#xff0c;就让我对一些事情有新的思考。。 今天前台同事&#xff0c;的机器突然上不了网&#xff0c;&#xff0c;和领导一起去看了一波&#…

Vue-12.集成postcss.config.js

PostCSS 介绍 PostCSS 是一个用于处理样式的工具&#xff0c;可以通过插件来定制其行为。以下是一些常用的 PostCSS 插件和 API 的介绍&#xff1a; Autoprefixer: 这是一个流行的 PostCSS 插件&#xff0c;用于自动添加浏览器前缀&#xff0c;以确保您的样式在不同浏览器中具…

jmeter CSV 数据文件设置

创建一个CSV数据文件&#xff1a;使用任何文本编辑器创建一个CSV文件&#xff0c;将测试数据按照逗号分隔的格式写入文件中。例如&#xff1a; room_id,arrival_date,depature_date,bussiness_date,order_status,order_child_room_id,guest_name,room_price 20032,2023-8-9 14:…

向量数据库 Milvus:实现高效向量搜索的技术解析

引言 随着人工智能、机器学习和深度学习技术的不断发展&#xff0c;越来越多的应用开始使用向量表示数据。向量数据具有高维、稀疏和相似性等特点&#xff0c;传统的关系型数据库和键值存储在处理这类数据时面临许多挑战。为了满足大规模、高并发的向量搜索需求&#xff0c;出现…

C++--动态规划两个数组的dp问题

1.最长公共子序列 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 &#xff0c;返回 0 。 一个字符串的 子序列 是指这样一个新的字符串…

Java Heap Space(堆内存溢出)问题 ,想找一个扫描代码的工具

以下是几个受欢迎的工具&#xff1a; FindBugs&#xff1a;它是一个静态代码分析工具&#xff0c;专门用于查找 Java 代码中潜在的 bug 和问题。它可以帮助您发现一些常见的内存泄漏和资源管理问题。 PMD&#xff1a;类似于 FindBugs&#xff0c;PMD 也是一个静态代码分析工具…

Nginx+Tomcat负载均衡、动静分离

目录 NginxTomcat负载均衡、动静分离群集 Nginx配置反向代理的主要参数 动静分离原理 反向代理两种模式 七层反向代理 四层反向代理 Nginx 负载均衡模式&#xff08;调度算法&#xff09; nginx的会话保持 为什么使用动静分离 为什么使用负载均衡 正向代理和反向代理…

Unity 之NavMeshAgent 组件(导航和路径寻找的组件)

文章目录 **作用**&#xff1a;**属性和方法**&#xff1a;**用途**&#xff1a;**注意事项**&#xff1a; NavMeshAgent 是Unity引擎中用于导航和路径寻找的组件。它可以使游戏对象在场景中自动找到可行走的路径&#xff0c;并在避免障碍物的情况下移动到目标位置。 以下是关于…

在当今信息化社会中的安全大文件传输

随着科技的不断进步&#xff0c;数据已经成为各个领域和行业的宝贵财富。然而&#xff0c;随之而来的数据传输和交换问题也成为一个日益突出的挑战。在这篇文章中&#xff0c;我们将探讨在当今信息化社会中的安全大文件传输的重要性&#xff0c;以及如何应对传统传输方式所面临…

穿起“新架构”的舞鞋,跳一支金融数字化转型的华尔兹

华尔兹&#xff0c;是男女两位舞者&#xff0c;通过形体的控制&#xff0c;舞步技巧的发挥&#xff0c;完美配合呈现而出的一种舞蹈形式。华尔兹舞姿&#xff0c;如行云流水、潇洒自如、飘逸优美&#xff0c;素有“舞中皇后”的美称。 在跳华尔兹的时候&#xff0c;如果舞者双…

SQL 盲注

问题描述&#xff1a; 解决方案&#xff1a; 通过建立过滤器方法 添加拦截器&#xff1a; web.xml 文件配置拦截器 <filter><filter-name>sqlFilter</filter-name><filter-class>com.fh.filter.SqlFilter</filter-class></filter> pack…

vue3 03-ref函数使用

使用ref创建响应式数据 只支持 简单or 复杂 数据转换 使用ref&#xff1a; 1.导入ref函数 2.创建响应式数据 3.返回数据 4.展示内容 <template><p> 年龄:{{ count }}</p><button click"count">加一岁</button><button click"…

Vue与React的对比(API)

组件传值 VUE // 父组件 <GoodsList v-if"!isGoodsIdShow" :goodsList"goodsList"/> // 子组件 -- 通过props获取即可 props: {goodsList:{type:Array,default:function(){return []}}}REACT // 父组件 export default function tab(props:any) {…

Python将网络文件下载到本地

Python将网络文件下载到本地 前言相关介绍Python将网络文件下载到本地 前言 由于本人水平有限&#xff0c;难免出现错漏&#xff0c;敬请批评改正。更多精彩内容&#xff0c;可点击进入Python日常小操作专栏、YOLO系列专栏、自然语言处理专栏或我的个人主页查看基于DETR的人脸伪…

【Git版本控制工具使用---讲解一】

Git版本控制工具使用 安装设置用户名签名和邮箱Git常用的命令 初始化本地库查看本地状态Git 命令添加暂存区提交本地库查看版本信息修改文件版本穿梭 安装 首先根据自身电脑的配置选择性的安装是32位的还是64位的Git版本控制工具 我这边安装的是64位的 以下是我安装的时候的过…

信号的傅里叶分析之傅里叶级数

1 为什么要进行傅里叶分析 信号分析方法主流方法有&#xff1a; &#xff08;1&#xff09;时域分析&#xff1a;以冲激信号为基本信号&#xff0c;任意输入信号可分解为一系列冲激信号&#xff1b; &#xff08;2&#xff09;频域分析&#xff1a;以正弦信号和虚指数信号为基…

springboot2+redis 订阅发布,解决接收消息累计线程到内存溢出,使用自定义线程池接收消息

pom 添加redis <!-- redis 缓存操作 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency> 发布消息 import lombok.extern.slf4j.Slf4j; import o…

python 连接Redis 数据库

pip install redis python代码 import redis# 连接数据库 r redis.Redis(host192.168.56.15, port6379, db0)# 存储数据 #r.set(key, value) r.set(name, zaraNet)# 获取数据 value r.get(name) print(value)# 关闭连接&#xff08;可选&#xff09; r.close()