vue弹出框组件封装实例代码
新学vue,参考别人封装弹出层组件。好用!
1.你需要先建一个弹出框的模板:
//首先创建一个mack.vue{{text.title.trim()}}
新学vue,参考别人封装弹出层组件。好用!
1.你需要先建一个弹出框的模板:
//首先创建一个mack.vue{{text.title.trim()}}
2.接着你需要一个js:mackjs.js
importVuefrom'vue'; importconfirmfrom'./mack'; letconfirmConstructor=Vue.extend(confirm); lettheConfirm=function(text){ returnnewPromise((res,rej)=>{//promise封装,ok执行resolve,no执行rejectlet letconfirmDom=newconfirmConstructor({ el:document.createElement('div') }) document.body.appendChild(confirmDom.$el);//new一个对象,然后插入body里面 confirmDom.text=Object.assing(confirmDom.text,text);//为了使confirm的扩展性更强,这个采用对象的方式传入,所有的字段都可以根据需求自定义 confirmDom.ok=function(){ res() confirmDom.isShow=false } confirmDom.close=function(){ rej() confirmDom.isShow=false } }) } exportdefaulttheConfirm; //暴露出去,别忘记挂载到vue的原型上 //=>在main.js里面先引入importtheConfirmfrom'./components/confirm/confirm.js' //=>再挂载Vue.prototype.$confirm=theConfirm; //在需要的地方直接用以下方法调用即可: //this.$confirm({ //type:'提示', //msg:'是否删除这条信息?', //btn:{ //ok:'yes', //no:'no' //} //}).then(()=>{ //console.log('ok') //}) //.catch(()=>{ //console.log('no') //})
-3.你接着需要在main.js导入这个文件
importmacksjsfrom'./assets/mackjs' Vue.prototype.$confirm=macksjs;
-4.最后在你需要引入的vue文件中直接调用就好了
methods:{ deleteaas(){ this.$confirm({ title:"addd", mesg:"您确定不再关注该客户吗?", cntMsg:'你好', cancelValStyle:{color:'red'}, btn:{ confirmVal:"确a定", cancelVal:"取a消" } }) .then(()=>{ console.log("yes"); //点击确定之后的处理 }) .catch(()=>{ console.log("no"); }); } }
导入
总结
以上所述是小编给大家介绍的vue弹出框组件封装实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。