十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
本篇文章为大家展示了如何在Vue中自定义一个toast组件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
创新互联服务项目包括彝良网站建设、彝良网站制作、彝良网页制作以及彝良网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,彝良网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到彝良省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!第一步:写toast.vue,将样式之类的先定下来
{{message}}{{message}}{{message}}
一共三种样式,成功(success),失败(wrong),加载中(loading);
一共三种位置,上(top),中(middle),下(bottom);
所有涉及的图案出自阿里的iconfont 手机淘宝图标库。
加载中动画是自己写的蹩脚的加载组件(emmm,就不放出来污染大家眼睛了,需要的可以评论区知会一声_(:з」∠)_)
第二步:写index.js ,完成toast组件的实例化
import Vue from 'vue' import Toast from './toast' let singleToast=true; let queue=[]; function createInstance(){ // 返回一个扩展实例构造器 if(!queue.length||!singleToast){ const ToastConstructor = Vue.extend(Toast); // 构造一个实例 const toastDom = new ToastConstructor({ el: document.createElement('div'), }); // 把实例化的 toast.vue 添加到 body 里 document.body.appendChild(toastDom.$el); queue.push(toastDom); singleToast=true; return toastDom; } }; // 注册为全局组件的函数 function toast(options= {}) { const toastDom = createInstance(); toastDom.message =typeof options === 'string' ? options : options.message; toastDom.type = options.type || 'success'; toastDom.duration = options.duration || 3000; toastDom.position = options.position || 'middle'; if(!toastDom.message){ toastDom.showToast =singleToast= false; }else{ toastDom.showToast=true; setTimeout(() => {toastDom.showToast =singleToast= false} ,toastDom.duration); } } // 将组件注册到 vue 的 原型链里去, // 这样就可以在所有 vue 的实例里面使用 this.$toast() // Vue.prototype.$toast = showToast Vue.prototype.$toast = toast; export default toast
设置singleToast和queue的目的在于:确保同一时期界面上只有一个toast,不能同时出现多个toast。
由于toast会初始化,因此为了避免在任何操作之前界面上就出现一个toast,用if语句判断:
如果没有传入的message,则不显示toast(这样可以使得初始化的toast不显示)
否则显示,并且过一定时间消失,只有singleToast为false,说明此刻界面上没有toast,才能再新建一个toast实例(因为此时if判断内queue.length 不为0【初始化的toast组件本身占了一个位置】,而singleToast为false,因此可以创建)
第三步:使用
在main.js 添加如下代码:
import toast from './components/toast/index' Vue.use(toast)
创建需要调用的Vue文件:
上述内容就是如何在Vue中自定义一个toast组件,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联成都网站设计公司行业资讯频道。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。