react使用dangerouslySetInnerHTMl 渲染后端传递的数据中的html标签

原理:

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>;
  };

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值