写了两三天,终于把toast组件写出来了。不敢说是最好的设计,希望有更好思路的朋友可以在评论区给我意见!_(:з」∠)_
第一步:写toast.vue,将样式之类的先定下来
一共三种样式,成功(success),失败(wrong),加载中(loading);
一共三种位置,上(top),中(middle),下(bottom);
所有涉及的图案出自阿里的iconfont 手机淘宝图标库。
加载中动画是自己写的蹩脚的加载组件(emmm,就不放出来污染大家眼睛了,需要的可以评论区知会一声_(:з」∠)_)
第二步:写index.js ,完成toast组件的实例化
设置singleToast和queue的目的在于:确保同一时期界面上只有一个toast,不能同时出现多个toast。
由于toast会初始化,因此为了避免在任何操作之前界面上就出现一个toast,用if语句判断:
如果没有传入的message,则不显示toast(这样可以使得初始化的toast不显示)
否则显示,并且过一定时间消失,只有singleToast为false,说明此刻界面上没有toast,才能再新建一个toast实例(因为此时if判断内queue.length 不为0【初始化的toast组件本身占了一个位置】,而singleToast为false,因此可以创建)
第三步:使用
可以看到一共两种方式,可以以对象方式传入参数,也可以只传入字符串,其他采用默认设置。
以上所述是小编给大家介绍的SVue自定义toast组件的实例代码。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。