温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

vue弹窗组件怎么用

发布时间:2021-06-26 15:27:15 来源:亿速云 阅读:197 作者:小新 栏目:web开发

这篇文章主要为大家展示了“vue弹窗组件怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue弹窗组件怎么用”这篇文章吧。

具体内容如下

弹窗是一个项目必备的复用利器,所以封装起来,保证项目ui一致,是很有必要的。学了一段时间vue,想想还是用vue写一下吧。用的很小白,但是会写出来了,说明我也有进步一丢丢了。继续加油….

代码贴图如下,样式比较丑,不要介意…

<!DOCTYPE html> <html lang="en"> <head>   <meta charset="UTF-8">   <title>ys-vue-modal-component</title>   <style>     p,h5{       margin:0;     }     .modal{       width: 480px;       background-color: #fff;       border: 1px solid rgba(0, 0, 0, .3);       border-radius: 6px;       box-shadow: 0 4px 12px rgba(0, 0, 0, .5);       margin: 50px;     }     .modal-header {       color: #fff;       background: cadetblue;       border-radius: 6px 6px 0 0;       padding: 15px;       border-bottom: 1px solid #5e9fa1;     }     .modal-content div {       padding: 15px 10px;     }     .modal-footer {       padding: 15px;       text-align: right;       border-top: 1px solid #e5e5e5;     }     .btn {       border: 1px solid #d1d1d1;       border-radius: 3px;       background-color: #f7f7f7;       background: -webkit-gradient(linear, 0 0, 0 100%, from(#f7f7f7),      to(#f2f2f2));       background: -moz-gradient(linear, 0 0, 0 100%, from(#f7f7f7),      to(#f2f2f2));       background: -o-gradient(linear, 0 0, 0 100%, from(#f7f7f7), to(#f2f2f2));       background: -ms-gradient(linear, 0 0, 0 100%, from(#f7f7f7), to(#f2f2f2));       height: 28px;       padding: 0 20px;       cursor: pointer;       line-height: 28px;       display: inline-block;       color: #666666;       margin-right: 5px;       outline: none;     }     .blue {        border: 1px solid #5e9fa1;       background-color: #5e9fa1;       background: -webkit-gradient(linear, 0 0, 0 100%, from(#74c4c6),      to(#5e9fa1));       background: -moz-gradient(linear, 0 0, 0 100%, from(#74c4c6),      to(#5e9fa1));       background: -o-gradient(linear, 0 0, 0 100%, from(#74c4c6), to(#5e9fa1));       background: -ms-gradient(linear, 0 0, 0 100%, from(#74c4c6), to(#5e9fa1));       color: #FFFFFF;     }       </style>   <script src="https://unpkg.com/vue/dist/vue.js"></script> </head> <body>   <div id="app">      <input type="button" class="btn blue" value="点击我,呼唤弹窗,再来一遍" v-if="isHide" @click="isHide=!isHide">     <ys-modal-component         v-if="!isHide"        modal-title="温馨提示"         ok-btn="确认购买"         cancel-btn="去意已决"        @on-ok="ok"        @on-cancel="cancel"      >       <div slot="modal-content">         尊敬的用户,您购买的商品将于支付成功后3-7个工作日内发货,敬请周知。祝您购物愉快!       </div>     </ys-modal-component>   </div>   <script>     /*       props:         modalTitle: 弹窗标题         okBtn: 确认按钮         cancelBtn: 取消按钮         注意事项:传参时候使用烤串的书写方式xx-xxx       slot:         modal-content: 内容区域         modal-footer: 页脚按钮区域       methods:          okHandle: 触发确认on-ok自定义事件         cancelHandle: 触发取消on-cancel自定义事件      */     Vue.component('ys-modal-component', {       props: {         modalTitle: {           type: String,           default: '标题区域'         },         okBtn: {           type: String,           default: '确认'         },         cancelBtn: {           type: String,           default: '取消'         }       },       template: `         <div class="modal">           <div class="modal-header">             <h5>{{ modalTitle }}</h5>           </div>           <div class="modal-content">             <div>               <slot name="modal-content">内容区域</slot>             </div>           </div>           <div class="modal-footer">               <input class="btn blue" type="button" v-model="okBtn" @click="okHandle" />               <input class="btn" type="button" v-model="cancelBtn" @click="cancelHandle" />           </div>         </div>       `,       methods: {         okHandle () {           console.log("点击确定");           this.$emit("on-ok");          },         cancelHandle () {           console.log("点击取消");           this.$emit("on-cancel");         }       }     })     new Vue({       el: "#app",       data: {         isHide: false       },       methods: {         ok () {           alert("欢迎您购买本产品");         },         cancel () {           this.isHide = !this.isHide;         }       }     })   </script> </body> </html>

以上是“vue弹窗组件怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI