react 如何渲染富文本内容
import React, { Component } from 'react';class App extends Component {constructor(){super()this.state={article:"<div>我是富文本内容</div>",}}render() {return (<div dangerouslySetInnerHTML={{__
·
import React, { Component } from 'react';
class App extends Component {
constructor(){
super()
this.state={
article:"<div>我是富文本内容</div>",
}
}
render() {
return (
<div dangerouslySetInnerHTML={{__html:this.state.article}}></div>
);
}
}
export default App
在react中,通过富文本编辑器进行操作后的内容,会保留原有的标签样式,并不能正确展示。
在显示时,将内容写入__html对象中即可。具体如下:
-
dangerouslySetInnerHTMl 是React标签的一个属性,类似于angular的ng-bind;
-
有2个{{}},第一{}代表jsx语法开始,第二个是代表dangerouslySetInnerHTML接收的是一个对象键值对;
-
既可以插入DOM,又可以插入字符串;
-
不合时宜的使用 innerHTML 可能会导致 cross-site scripting (XSS) 攻击。 净化用户的输入来显示的时候,经常会出现错误,不合适的净化也是导致网页攻击的原因之一。dangerouslySetInnerHTML 这个 prop 的命名是故意这么设计的,以此来警告,它的 prop 值( 一个对象而不是字符串 )应该被用来表明净化后的数据。
相关资料:
http://wiki.jikexueyuan.com/project/react/dangerously.html
更多推荐
所有评论(0)