我有一个变量里面的字符串: var template = 'divHello {username}/div'; 用户名是由州设置的,如何解析此字符串并将其转换为反应组件? 使用RegExp标识所有{}集.然后,将值替换为状态值并更新字符
var template = '<div>Hello {username}</div>';
用户名是由州设置的,如何解析此字符串并将其转换为反应组件?
使用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="http://img.558idc.com/uploadfile/allimg/210615/1PU32507-0.jpg"></script> <script src="http://img.558idc.com/uploadfile/allimg/210615/1PU354X-1.jpg"></script> <div id="app"></div>