ant design vue Message 用法以及内容为 html片段情况

ant design vue 的 Message 用法

全局展示操作反馈信息

何时使用 #

  1. 可提供成功、警告和错误等反馈信息。
  2. 顶部居中显示并自动消失,是一种不打断用户操作的轻量级提示方式。

全局配置:

复制代码
// main.ts

// 进行全局配置
message.config({
  top: `0.7rem`,//高度位置
  duration: 2,//提示持续时间
  maxCount: 1,//最大页面同时展示几条
});

项目中最常用的用法:

1、字符串

复制代码
message.success("导入成功");

2、html片段

复制代码
message.error({
      content: h(
        "span",
        { style: "display: inline-table;text-align: left;" },"通知内容"
      ),
    });

我这边项目传过来的数据可能参杂<br>,所以我封装了个公共方法:

复制代码
// utils.ts

import { h } from "vue";
import { message } from "ant-design-vue";
// 接口返回html字段根据<br>进行拆分处理
export function htmlToList(msg: string, type?: string) {
  const lines = msg.split("<br>");
  if (type && type == "warning") {
    message.warning({
      content: h(
        "span",
        { style: "display: inline-table;text-align: left;" },
        lines.map((line, index) => {
          return [
            h("span", null, line),
            index < lines.length - 1 ? h("br") : null,
          ];
        })
      ),
    });
  } else {
    message.error({
      content: h(
        "span",
        { style: "display: inline-table;text-align: left;" },
        lines.map((line, index) => {
          return [
            h("span", null, line),
            index < lines.length - 1 ? h("br") : null,
          ];
        })
      ),
    });
  }
}

因为ant design vue中message并不像element-plus中存在

属性,而是

所以需要借助vue3中的h函数( createVNode)去创造虚拟dom

相关推荐
To_OC5 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC5 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
天渺工作室6 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny6 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi6 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒7 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__7 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒10 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户479492835691511 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔12 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js