antdv中Notification组件换行的两种方式

业务需求中,有这样一个反馈信息,需要根据;进行换行并通过Notification组件展示:

const msg = "我是反馈信息1;我是反馈信息2;我是反馈信息3"

常规的Notification使用并不会自动换行,但是官方文档中description不仅可以使用string,还可以使用VNode

官方文档

众所周知,Vue中构造一个VNode的语法为h函数:

h(nodeType, nodeConfig, nodeInnerHTML)

我们第一种方式可以使用HTML中pre标签结合\n换行:

		description: ()=>{
			// 将反馈信息中所有;替换为\n换行符
            const res = msg.replaceAll(';','\n')
            return h('pre',{},res)
          },

第二种方式较为繁琐,将每一个被分号切割的字符串都转为VNode,可定制化程度更高:

		 description: () => {
		 	// 将反馈信息使用;分割为数组
            const splitText = msg?.split(';') ?? []
            // 数组中每项反馈信息都转为VNode
            const res = _.map(splitText, (item) => {
              return h('p', {
                style: {
                  'margin-bottom': 0,
                  'font-size': 'small'
                }
              }, item)
            })
            // 返回总的VNode,子元素为所有反馈信息
            return h('p', {
              style: {
                overflow: 'scroll',
                height: '80vh'
              }
            }, res)
          },
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值