真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用Vue怎么實現(xiàn)一個命令式彈窗組件

這篇文章將為大家詳細講解有關使用Vue怎么實現(xiàn)一個命令式彈窗組件,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

公司主營業(yè)務:網(wǎng)站制作、成都網(wǎng)站設計、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出滄縣免費做網(wǎng)站回饋大家。

使用方式:

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

目錄結構

使用Vue怎么實現(xiàn)一個命令式彈窗組件

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

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

知識點

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

1. extend

使用Vue怎么實現(xiàn)一個命令式彈窗組件

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

2. $mount

使用Vue怎么實現(xiàn)一個命令式彈窗組件

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

3. $el

使用Vue怎么實現(xiàn)一個命令式彈窗組件

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

代碼實現(xiàn)

index.vue


.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;
}

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)一個命令式彈窗組件就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


本文標題:使用Vue怎么實現(xiàn)一個命令式彈窗組件
文章轉載:http://weahome.cn/article/jsdpjg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部