样式标签在渲染时从 ReactJS 组件中完全消失

style tag completely disappears from ReactJS component on render

这是代码,不确定这是 React 的问题还是简单的拼写错误,但是一旦这个组件呈现,整个样式标签就会消失。这段代码所做的是每 750 毫秒将变换比例更改为 0 到 0.5 之间的随机大小,但如前所述,它甚至在渲染标签时也有问题,这很奇怪。

let styles = { 
    transform: `scale(0.5);` 
}

function changeStyle() {
    var r = -0.1 + Math.random() * (0.2 - 0) + 0;
    styles = { 
        transform: `scale(${r});` 
    };
    setTimeout(changeStyle, 750);
}

changeStyle();

export default class Runaway extends Component {

    componentDidMount() {
        console.log("Booting up Runaway button v1 by Ashe Muller.")
    }

    render() {
        return (
            <div style={{styles}}>
                <text id="shopItemGrid">RUN AWAY</text>
            </div>
        )
    }
}

你的 let 'styles' 已经是一个对象,应该传递给你的 div 样式:

<div style={styles}>

这样结果就是:

<div style={{ transform: `scale(0.5);` }}>

在你的例子中,你添加了一个层次的对象,最后你的风格看起来像这样:

style={{ styles : { transform: `scale(0.5);` }}

这不是有效的样式。

现在代码的结构方式,styles 永远不会改变,因为 changeStyle() 永远不会在组件中被调用。

尝试这样的事情:

export default class Runaway extends Component {
  constructor() {
      super();
      this.state = {
        transform: 'scale(0.5)'
      }
  }

  handleTransformChange = () => {
    var r = -0.1 + Math.random() * (0.2 - 0) + 0;
    var newTransform = `scale(${r})`;
    this.setState({
      transform: newTransform
    });
  }

  componentDidMount() {
    console.log("Booting up Runaway button v1 by Ashe Muller.")
    this.timer = setInterval(
      () => this.handleTransformChange(),
      750
    );
  }

  componentWillUnmount() {
    clearInterval(this.timer);
  }

  render() {
    let styles = { 
      transform: this.state.transform
    };

    return (
      <div style={styles}>
        <text id="shopItemGrid">RUN AWAY</text>
      </div>
    );
  }
}