使用vue实现注册一个全局的Toast

最近碰到一个实现全局toast的面试题,然后翻阅资料发现Vue提供了Vue.extend()可以实现这个功能,后续封装其他业务组件时也可使用此方法。以此文章以作笔记。

题目大概如下:

    Toast支持string/object两种类型的调用,其基本的样式为垂直/水平居中于屏幕中央,图片文字上下混排

首先

我先准备好一个vue2.x的项目,然后写好一个组件Toast。一般我会放在components目录下。

// toast.vue文件
<template>
    <div class="toast" v-if="show">
      <div>
        <img v-if="imgUrl" :src="imgUrl" alt="">
      </div>
      <span>{{ msg }}</span>
    </div>
</template>

<style scoped>
    .toast{
      position: fixed;
      left: 50%;
      top: 50%;
      transform: translate(-50%,-50%);
      border-radius: 3px;
      max-width: 200px;
      padding: 10px;
      background: #333;
      color: #fff;
      font-size: 14px;
      opacity: .9;
      text-align: justify;
      word-break: break-all;
      word-wrap: break-word;
      display: flex;
      flex-direction: column;
      align-items: center;
    }
    .toast img{
      width: 50px;
      height: 50px;
    }
</style>

这里就是vue文件的样式结构代码。其中通过show参数来控制toast的显示隐藏,imgUrl参数控制传入的图片,msg参数代表轻提示的文案。

第二步

在plugins目录下建了个toast.js文件,代码如下:

import toast from "@/components/toast"
export default (Vue) => {
    let toastComp = Vue.extend(toast);
    function showToast(msg ,imgUrl = '', duration = 3e3){
        let toastDom = new toastComp({
            data(){
                return{
                    show: true,
                    msg: typeof msg === 'object'? msg.msg: msg,
                    imgUrl: typeof msg === 'object'? msg.imgUrl: imgUrl,
                }
            }
        }).$mount()
        document.body.appendChild(toastDom.$el);
        setTimeout(() => {
            toastDom.show = false
        }, duration)
    }
    Vue.prototype.$toast = showToast;
}
  1. Vue.extend: 可以简单的理解为当在模板中遇到该组件名称作为标签的自定义元素时,会自动调用扩展实例构造器来生产组件实例,并挂载到自定义元素上。官网地址:https://cn.vuejs.org/v2/api/#Vue-extend

  2. 通过new创建实例传入的data函数代表的就是toast.vue文件里面的data对象,所以可以直接在toast.vue文件中直接使用这些

  3. 在通过appendChild方法把他添加到document.body中。

  4. setTimeout就是用来控制toast显示的时间。

  5. 最后把方法挂在到全局变量vue的身上,这样就能通过this来调用。

第三步

在main.js中引入使用

import toast from "@/plugins/toast";
Vue.use(toast);

最后在组件中使用


//字符串调用
this.$toast("message","https://img1.baidu.com/it/u=3548238993,1758041513&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500", 3000);
 
//object方式调用
// this.$toast({
//     msg: 'toast',
//     imgUrl: 'https://img1.baidu.com/it/u=3548238993,1758041513&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500'
// });

效果如下:

在这里插入图片描述

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
Vue全局引入vant组件可以通过在main.js中使用Vue.use()方法来实现。例如,可以使用以下代码将vant的Button组件全局引入: ```javascript import { Button } from 'vant' Vue.use(Button) ``` 如果需要引入多个vant组件,可以使用链式调用的方式: ```javascript import { Button, Row, Col } from 'vant' Vue.use(Button).use(Row).use(Col) ``` 另外,如果需要在Vue实例中使用vant的Toast和Loading组件,可以在main.js中进行全局引入,并将其挂载到Vue的原型上,以便在其他组件中使用: ```javascript import { Toast, Loading } from 'vant' import 'vant/lib/index.css' Vue.prototype.$toast = Toast Vue.prototype.$loading = Loading ``` 全局引入vant组件的优点是可以在所有的Vue文件的template中直接使用所需的组件。然而,缺点是在打包发布时会增加包的大小,可能会导致首屏加载速度变慢。此外,全局引入的组件无法在js中使用类似Toast功能的组件。 #### 引用[.reference_title] - *1* [在vue项目中使用vant(全局引入,按需引入,页面中引入)](https://blog.csdn.net/haoxinqing222/article/details/108236351)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [vue移动端UI框架——Vant全局引入vs局部引入](https://blog.csdn.net/u013205165/article/details/99645847)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

杨小凹

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

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

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

打赏作者

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

抵扣说明:

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

余额充值