全局弹窗组件实现

全局弹窗组件实现

使用函数式组件实现。框架采用Vue、bootstrap。

当我们写好一个组件时,这个组件功能大体上可能都是差不多的,但是要在很多地方调用,通常的组件要在template中引入才行。

在饿了么UI组件中,有的对话框组件只是调用函数即可完成,通常来说组件调用不应该很麻烦,在原生的JS中调用警告提示只需要alert即可。

效果展示

在这里插入图片描述

实现方式

按照bootstrap的要求大体布置如下,在div标签中判断当前需要什么样的组件类型。之后只需要传递:消息、消息类型、关闭按钮逻辑。

<svg style="display: none" xmlns="http://www.w3.org/2000/svg">
  <symbol id="check-circle-fill" viewBox="0 0 16 16">
   <path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.06L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z" />
  </symbol>
  <symbol id="info-fill" viewBox="0 0 16 16">
   <path
    d="M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2z"
   />
  </symbol>
  <symbol id="exclamation-triangle-fill" viewBox="0 0 16 16">
   <path
    d="M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z"
   />
  </symbol>
</svg>

<div :class="`alert alert-${type} d-flex align-items-center animate__animated animate__fadeIn`" role="alert">
  <svg v-show="type === 'info'" aria-label="Info:" class="alter-svg bi bi-exclamation-triangle-fill flex-shrink-0 me-2" role="img">
   <use xlink:href="#info-fill" />
  </svg>
  <svg v-show="type === 'success'" aria-label="Success:" class="alter-svg bi bi-exclamation-triangle-fill flex-shrink-0 me-2" role="img">
   <use xlink:href="#check-circle-fill" />
  </svg>
  <svg v-show="type === 'warning'" aria-label="Warning:" class="alter-svg bi bi-exclamation-triangle-fill flex-shrink-0 me-2" role="img">
   <use xlink:href="#exclamation-triangle-fill" />
  </svg>
  <svg v-show="type === 'danger'" aria-label="Danger:" class="alter-svg bi flex-shrink-0 me-2" role="img">
   <use xlink:href="#exclamation-triangle-fill" />
  </svg>

  <div>{{ message }}</div>
  <button aria-label="Close" class="btn-close" data-bs-dismiss="alert" style="margin: 0 0 0 8px; width: 4px; height: 15px" type="button" @click="close"></button>
</div>
<style lang="scss" scoped>
.alert {
	position: fixed;
	top: 10%;
	left: 50%;
	transform: translate(-50%, -10%);
	height: 30px;
	z-index: 99999;

	.alter-svg {
		width: 15px;
		height: 30px;
	}
}
</style>

props内容

<script lang="ts" setup>
defineProps(['message', 'type', 'close']);
</script>

封装成函数使用

import { App, createApp } from 'vue';
import Alerts from '@/components/Message/index.vue';

/**
 * 函数式消息组件
 * @param message
 * @param type
 */
const handleMessage = (message: string, type: string) => {
  // 创建标签并将标签放到body上
  const mountNode: any = document.createElement('div');
  document.body.appendChild(mountNode);

  // 配置内容是组件中的props
  const app: App<Element> = createApp(Alerts, {
   message,
   type,
   close: () => {
    app.unmount();
    document.body.removeChild(mountNode);
   },
  });

  // 挂载组件
  app.mount(mountNode);

  // 定时关闭
  setTimeout(() => {
   app.unmount();
   document.body.removeChild(mountNode);
  }, 2000);
};

export const Message = {
  success: (message: string) => handleMessage(message, 'success'),
  error: (message: string) => handleMessage(message, 'danger'),
  primary: (message: string) => handleMessage(message, 'info'),
  warning: (message: string) => handleMessage(message, 'warning'),
};

createApp(组件名称,props函数),props中内容在{}中完成。

创建组件之后记得销毁。

在这里插入图片描述

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3封装全局弹窗组件的步骤如下: 1. 创建一个Vue实例,作为全局弹窗组件的容器。可以使用`createApp`方法创建Vue实例,并将其挂载到一个DOM元素上。 2. 在全局弹窗组件上定义必要的属性和方法。比如,可以定义一个`visible`属性控制弹窗的显示与隐藏,一个`title`属性用于显示弹窗的标题,一个`content`属性用于显示弹窗的内容等。 3. 在全局弹窗组件内部实现弹窗的样式和交互逻辑。可以使用Vue的模板语法和样式定义实现弹窗的外观和样式效果,并通过Vue的响应式特性,实现弹窗的交互逻辑,比如点击关闭按钮时隐藏弹窗。 4. 添加全局方法,在Vue实例的原型上添加一个方法,用于在任意组件中调用弹窗组件。可以使用`app.config.globalProperties`来添加全局方法,以便在任何地方都可以访问到该方法。 5. 在组件中使用全局弹窗组件。在需要显示弹窗组件中,通过调用全局方法来调用弹窗组件。可以通过传递参数的方式,动态设置弹窗的内容和样式。 6. 在全局弹窗组件的内部实现弹窗的生命周期钩子函数,比如`mounted`函数用于在弹窗组件被挂载到DOM后执行相应的逻辑。 通过以上步骤,就可以封装一个可在任何组件中使用的全局弹窗组件。在使用过程中,只需要调用全局方法,传入相应的参数,即可显示自定义的弹窗内容和样式,提供更好的用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值