您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“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彈窗組件怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。