【UI】将 naive ui 的 message 封装进axios 中,关于naiveui的message相关的用法

在这里插入图片描述

参考文章:

关于naiveui的message相关的用法

前言

最近新建了一个vite + vu3 的项目,完全是从0 到1 ,封装到request 的时候 想对axios 请求做一个全局的处理,但发现naive uimessage 不像element ui 那样使用起来方便。多方查找资料文章终于将 message 封装进request 中,算是解决了这个问题。写这篇文章记录加深印象,防止下次再遇到。

在setup外进行使用

如果你想在 setup 外使用 useDialog、useMessage、useNotification、useLoadingBar,可以通过 createDiscreteApi 来构建对应的 API。

直接上代码,在请求的api中使用,代码如下:

//request.js
import { createDiscreteApi } from "naive-ui";
const { message } = createDiscreteApi(["message"]);
//
 
if (response.data.code == 500) {
      // 错误弹窗提示
      message.error(response.data.msg);
}

直接包裹使用

我们使用官方的案例,看了半天,先贴官方解释

如果你想使用信息,你需要把调用其方法的组件放在 n-message-provider 内部并且使用 useMessage 去获取 API
如果你想知道如何在 setup 外使用,请参考页面最下方的 Q & A。

官方例子:

<!-- App.vue -->
<n-message-provider>
  <content />
</n-message-provider>

不少同学还是不知道咋用,往下看,复制粘贴就完事

App.vue

<template>
  <n-config-provider>
    <n-modal-provider>
      <n-message-provider>
        <router-view />
        <TheMessage></TheMessage>
      </n-message-provider>
    </n-modal-provider>
  </n-config-provider>
</template>
 
<script setup>
import { NConfigProvider } from "naive-ui";
</script>

<style scoped></style>

vue 单文件中使用

至于在vue文件中使用,直接引入使用就好

import { useMessage } from 'naive-ui'
const message = useMessage()
message.warning('hello')
好的,这里是一个使用 naive-ui 的 menu 组件并使用 show 属性的示例代码: ```vue <template> <na-menu> <na-submenu name="sub1" title="Submenu"> <na-menu-item name="item1">Item 1</na-menu-item> <na-menu-item name="item2">Item 2</na-menu-item> <na-submenu name="sub1-1" title="Submenu 1"> <na-menu-item name="item3">Item 3</na-menu-item> <na-menu-item name="item4">Item 4</na-menu-item> </na-submenu> </na-submenu> <na-submenu name="sub2" title="Disabled Submenu" disabled> <na-menu-item name="item5">Item 5</na-menu-item> <na-menu-item name="item6">Item 6</na-menu-item> <na-submenu name="sub2-1" title="Submenu 2"> <na-menu-item name="item7">Item 7</na-menu-item> <na-menu-item name="item8">Item 8</na-menu-item> </na-submenu> </na-submenu> <na-menu-item name="item9">Item 9</na-menu-item> </na-menu> </template> <script> import { defineComponent } from 'vue' import { NMenu, NSubmenu, NMenuItem } from 'naive-ui' export default defineComponent({ components: { NMenu, NSubmenu, NMenuItem }, data () { return { show: false } }, methods: { onOpen () { // 打开 submenu 的回调 this.show = true }, onClose () { // 关闭 submenu 的回调 this.show = false } } }) </script> ``` 在这个示例,我们创建了一个 menu 组件,其包含两个 submenu 和一个 menu-item。在 submenu 组件上我们设置了 show 属性,当 show 为 true 时,展开并显示该 submenu,反之则关闭。在 onOpen 和 onClose 方法,我们通过修改 show 属性的值来控制 submenu 的展开和关闭。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fruge365

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值