当前位置 : 主页 > 网页制作 > React >

reactjs – 如何将带有变量的字符串解析为react组件?

来源:互联网 收集:自由互联 发布时间:2021-06-15
我有一个变量里面的字符串: 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>
网友评论