gpt4 book ai didi

reactjs - 如何将带有变量的字符串解析到 react 组件中?

转载 作者:行者123 更新时间:2023-12-03 14:00:19 34 4
gpt4 key购买 nike

我有一个字符串,里面有一个变量:

var template = '<div>Hello {username}</div>';

用户名是由state设置的,如何解析这个字符串并将其转为react组件?

最佳答案

使用 RegExp 识别所有 {} 集。然后,将该值替换为状态值并更新字符串。最后使用dangerouslysetinnerhtml将 HTML 字符串插入到 React 节点中。请参阅示例。

希望这有帮助!

class App extends React.Component{
constructor(props) {
super(props)
this.state = {
username: 'Pranesh',
userId: 124,
}
}
render(){
var template = '<div>Hello {username}. Your user id is {userId}.</div>';
var r = template.match(/\{[\w]+\}/g);
r && r.forEach((state) => {
var regex = new RegExp(state, 'g')
var stateItem = state.split(/{|}/g)[1]
template = template.replace(regex, this.state[stateItem])
})
return <div dangerouslySetInnerHTML={{__html: template}}/>

}
}

ReactDOM.render(<App/>, document.getElementById('app'))
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<div id="app"></div>

关于reactjs - 如何将带有变量的字符串解析到 react 组件中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40209490/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com