欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue 實現(xiàn)一個命令式彈窗組件功能

 更新時間:2019年09月25日 08:13:51   作者:倚欄聽風  
這篇文章主要介紹了vue實現(xiàn)命令式彈窗組件功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

前言

在日常工作中彈窗組件是很常用的組件,但用得多還是別人的,空閑時間就自己來簡單實現(xiàn)一個彈窗組件

涉及知識點:extend、$mount、$el

使用方式:

this.$Confirm({
 title:'自定義標題'
}).then(res=>{
  console.log(res)
})

目錄結構

index.vue:組件布局、樣式、交互邏輯

index.js:掛載組件、暴露方法

知識點

在此之前,了解下涉及的知識點

1. extend

 使用這個api,可以將引入的vue組件變成vue構造函數(shù),實例化后方便進行擴展

2. $mount

我們希望彈窗組件是在使用時才顯示出來,那么就需要動態(tài)的向body中添加元素。使用$mount方法可以手動掛載一個vue實例,和 extend 剛好搭配使用,這個也是彈窗組件命令式的關鍵。

3. $el

 既然要添加dom元素,通過實例的$el屬性,正好可以取到dom元素,之后就是使用原生方法進行添加節(jié)點啦~

代碼實現(xiàn)

index.vue

<template>
  <div class="wrap">
    <div class="main">
      <div class="content">
        {{title}}
      </div>
      <div class="btn-grounp">
        <div class="btn cancel" @click="cancel">{{cancelText}}</div>
        <div class="btn confirm" @click="confirm">{{confirmText}}</div>
      </div>
    </div>
  </div>
</template>
<script>
export default {
  name:'',
  data () {
    return {
      title:'這是一個彈窗',
      confirmText:'確定',
      cancelText:'取消'
    };
  },
  methods: {
    show(cb){
      typeof cb === 'function' && cb.call(this,this)
      return new Promise(resolve=>{
        this.resolve = resolve
      })
    },
    confirm(){
      this.resolve('confirm')
      this.hide()
    },
    cancel(){
      this.resolve('cancel')
      this.hide()
    },
    hide(){
      document.body.removeChild(this.$el)
      this.$destroy()
    }
  },
}

</script>
<style scoped>
.wrap{
  position: fixed;
  top: 0;
  bottom:0;
  left:0;
  right:0;
  display:flex;
  justify-content: center;
  align-items: center;
  background: rgba(0,0,0,.3);
}
.main{
  width: 30%;
  padding: 10px;
  background: #fff;
  box-shadow: 0 0 10px 1px #ddd;
  border-radius: 5px;
}
.content{
  color:#424242;
  font-size: 20px;
}
.btn-grounp{
  margin-top: 15px;
  display:flex;
  justify-content: flex-end;
}
.btn{
  margin-left: 15px;
  padding: 5px 20px;
  border-radius: 5px;
  font-size: 16px;
  color:#fff;
}
.confirm{
  background: lightblue;
}
.cancel{
  background: lightcoral;
}
</style>

index.js

import Vue from 'vue'
import comfirm from './index.vue'
let newInstance = null
//將vue組件變?yōu)闃嬙旌瘮?shù)
let ConfirmConstructor = Vue.extend(comfirm)
let init = (options)=>{
  //實例化組件
  newInstance = new ConfirmConstructor()
  //合并配置選項
  Object.assign(newInstance,options)
  //加載dom
  document.body.appendChild(newInstance.$el)
}
let caller = (options)=>{
  //options 為調用組件方法時傳入的配置選項
  if(!newInstance){
    init(options)
  }
  return newInstance.show(vm =>{newInstance = null})
}
export default {
  install(vue){
    vue.prototype.$Confirm = caller
  }
}

main.js

上面我對外暴露的對象中含有install方法,這里可以使用Vue.use注冊組件(使用Vue.use后,會查找install方法進行調用),將組件調用方法掛載到Vue原型上。

import Confirm from './components/confirm'
Vue.use(Confirm)

寫在最后

這個彈窗組件比較簡陋,還有很多地方可以完善,等有時間再搞了~

總結

以上所述是小編給大家介紹的Vue 實現(xiàn)一個命令式彈窗組件功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

最新評論