原理:
在react中,通过富文本编辑器进行操作后的内容,会保留原有的标签样式,并不能正确展示。
1.dangerouslySetInnerHTMl 是React标签的一个属性,类似于angular的ng-bind;
2.有2个{undefined{}},第一{}代表jsx语法开始,第二个是代表dangerouslySetInnerHTML接收的是一个对象键值对;
3.既可以插入DOM,又可以插入字符串;
4.不合时宜的使用 innerHTML 可能会导致 cross-site scripting (XSS) 攻击。 净化用户的输入来显示的时候,经常会出现错误,不合适的净化也是导致网页攻击的原因之一。dangerouslySetInnerHTML 这个 prop 的命名是故意这么设计的,以此来警告,它的 prop 值( 一个对象而不是字符串 )应该被用来表明净化后的数据。
方法
// 高亮
const highlights = (text) => {
// const search = inputValue;
// let replaceReg = new RegExp(search, 'g'); // 匹配关键字正则
// let replaceString = '<span class="highlights-text">' + search + '</span>'; // 高亮替换v-html值
// text = text.replace(replaceReg, replaceString); // 开始替换
// return text;
text = text.replace(/\n/g, '<br>');
let html = { __html: text };
return <span dangerouslySetInnerHTML={html}></span>;
};
dom使用
{item.desc.map((v, i) => {
return (
<div key={i}>
{highlights(v.desc)}:{highlights(v.value)}
</div>
);
})}
拼接数据
// 占比数据拼接
const rateData = (data) => {
const list = data?.map(
(item) =>
`${item.name}占比<span class="redbold">${item.rate}%</span>,总共事件数为<span class="redbold">${item.value}</span>件`,
);
let html = { __html: `${list?.join('、')}。` };
return <span dangerouslySetInnerHTML={html}></span>;
};