在 React 中以编程方式修改元素:在 CSS 规则之前

Posted

技术标签:

【中文标题】在 React 中以编程方式修改元素:在 CSS 规则之前【英文标题】:Modify element :before CSS rules programmatically in React 【发布时间】:2017-07-25 22:28:56 【问题描述】:

我有一个元素,其:before 样式必须根据计算进行修改。

export class Content extends React.Component 
    render() 
        return (
            <div className="ring-base">
               <div className="ring-left" style=/* Change here */></div>
               <div className="ring-right" style=/* Change here */></div>
               <div className="ring-cover">
                   <div className="ring-text">10%</div>
               </div>
            </div>
        );
    

CSS 代码:

.ring-base 
    position: absolute;
    height: 200px;
    width: 200px;
    border-radius: 50%;
    background: red;
    transform: rotate(90deg);
    overflow:hidden;

.ring-cover 
    position: absolute;
    height: 180px;
    width: 180px;
    background: #fff;
    border-radius: 50%;
    top: 5%;
    left: 5%;


.ring-cover .ring-text 
    position: absolute;

    width: 100%;
    height: 100%;
    text-align: center;
    font-size: 2em;
    display: flex;
    justify-content:center;
    align-content:center;
    flex-direction:column;
    transform: rotate(-90deg);


.ring-right, .ring-left 
    height: 100px;
    width: 200px;
    overflow: hidden;
    position: absolute;  


.ring-right:before, .ring-left:before 
    height: inherit;
    width: inherit;
    position: absolute;
    content: "";
    border-radius: 100px 100px 0 0;
    background-color: grey;
    transform: rotate(0deg);


.ring-right 
    -webkit-transform-origin: 50% 0%;
    -moz-transform-origin: 50% 0%;
    -ms-transform-origin: 50% 0%;
    transform-origin: 50% 0%;
    transform: rotateZ(0deg);


.ring-left 
    transform: rotate(180deg);
    -webkit-transform-origin: 50% 100%;
    -moz-transform-origin: 50% 100%;
    -ms-transform-origin: 50% 100%;
    transform-origin: 50% 100%;


.ring-right:before 
    -webkit-transform-origin: 50% 100%;
    -moz-transform-origin: 50% 100%;
    -ms-transform-origin: 50% 100%;
    transform-origin: 50% 100%;
    transform: rotate(0deg);


.ring-left:before 
    -webkit-transform-origin: 50% 100%;
    -moz-transform-origin: 50% 100%;
    -ms-transform-origin: 50% 100%;
    transform-origin: 50% 100%;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);


要求能够通过 ReactJS 更新 .ring-left:before.ring-right:before 的转换属性。

如果有办法不更新 :before 类并将 CSS 更改为根本不使用 :before,那么也建议这样做。

Js-Fiddle

【问题讨论】:

创建新标签&lt;style&gt;并将您的计算作为内容,附加到headbody 见***.com/a/27255808 @Justinas 您指的是危险地设置 html 吗?这是我应该尝试的吗? (medium.learnreact.com/…) @guest271314 我不知道如何在 React 中使用 Jquery。有没有非 JQuery 的方式? @ManmeetS.Oberoi 为什么你认为动态设置 HTML 很危险? 【参考方案1】:

您可以迭代document.styleSheets,设置.style.cssRules 其中.selectorText 匹配伪选择器

let sheets = document.styleSheets;
let selector = "div::before";
let replacementContent = '"after"';
for (let sheet of sheets) 
  for (let rule of sheet.cssRules) 
    if (rule.selectorText === selector) 
      rule.style["content"] = replacementContent;
    
  
div:before 
  content: "before";
  color: red;
  font-weight: bold;
  text-align: center;
  text-shadow: 2px 2px 2px #000;
  background: green;
  width: 50px;
  height: 50px;
  display: block;
&lt;div&gt;&lt;/div&gt;

【讨论】:

哇,这太棒了。保存为书签,将来可能会派上用场。 这可以解决问题并按预期工作。谢谢。如果可能,请建议一种反应方式来复制相同的内容。 @ManmeetS.Oberoi 不确定什么是“反应方式”。在CSSStyleSheet 加载的答案集属性document 的方法。 这是遍历添加到项目中的所有样式表然后搜索选择器的暴力方式。如果我们可以添加一个支持伪元素的动态生成类,然后将其添加到特定的组件中。 @ManmeetS.Oberoi 您可以切换元素的.className 以将css 伪元素规则应用于类。或者,添加、删除具有.className 的元素,其中伪元素设置为css。本题询问如何修改现有的css::before伪元素规则。

以上是关于在 React 中以编程方式修改元素:在 CSS 规则之前的主要内容,如果未能解决你的问题,请参考以下文章

在 React-Router v4 中以编程方式导航

如何在 react-router 中以编程方式进行服务器端路由?

在 React-Router V4 中以编程方式设置路由参数最终会出现“找不到页面”

在 Asp.Net 中以编程方式添加样式表

Uncaught TypeError: (0 , _reactRouter.withRouter) 在 react-router 2.4.0 中以编程方式导航路由时不是一个函数

在 Xcode 5 中以编程方式修改 UINavigationcontroller