我想创建一个打字机动画 (类似于这个) 在我的es6组件中,即迭代地渲染传递的额外元素或字母。然而,无论何时我执行/渲染此组件,所有被渲染的只是“abc”集合中的第一个元素/字母“a”。超时时间正常工作,所以我认为for循环失败了。在es6中如何正确运行一个for循环并使用setTimeout函数,以便我的新元素可以被渲染呢?谢谢。
import React from 'react';
import { CSSTransitionGroup } from 'react-transition-group';
import Radium from 'radium';
export default class Logo extends React.Component {
constructor(props) {
super();
this.state = {
final: ''
}
this.typeWriter = this.typeWriter.bind(this);
}
typeWriter(text, n) {
if (n < (text.length)) {
let k = text.substring(0, n+1);
this.setState({ final: k });
n++;
setTimeout( () => { this.typeWriter(text, n) }, 1000 );
}
}
render() {
this.typeWriter('abc', 0);
return (
<div>
<h1>{this.state.final}</h1>
</div>
);
}
}
module.exports = Radium(Logo);