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

使用vue實(shí)現(xiàn)各類彈出框組件

 更新時(shí)間:2019年07月03日 10:15:33   作者:kuke_kuke  
這篇文章主要介紹了使用vue實(shí)現(xiàn)各類彈出框組件,文中給大家提到了vue中常用的dialog組件的封裝,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

這里寫圖片描述

簡(jiǎn)單介紹一下vue中常用dialog組件的封裝:

實(shí)現(xiàn)動(dòng)態(tài)傳入內(nèi)容,實(shí)現(xiàn)取消,確認(rèn)等回調(diào)函數(shù)。

首先寫一個(gè)基本的彈窗樣式,如上圖所示。

在需要用到彈窗的地方中引入組件:

import dialogBar from './dialog.vue'
components:{
  'dialog-bar': dialogBar,
},
<dialog-bar></dialog-bar>

點(diǎn)擊一個(gè)按鈕顯示彈窗,并保證關(guān)閉彈窗后再次點(diǎn)擊依舊顯示

在彈窗組件中定義一個(gè)value值:v-model="sendVal",sendVal初始值為false。

在打開(kāi)彈窗的方法中賦值:

openMask(){
  this.sendVal = true;
}

在dialog.vue組件中做如下操作:

props: {
  value: {}  // 注意此處獲取的value對(duì)應(yīng)的就是組件標(biāo)簽中的v-model
}

定義一個(gè)showMask變量用于控制是否顯示彈窗

mounted(){
  this.showMask = this.value;  // 在生命周期中,把獲取的value值獲取給showMash
},
watch:{
  value(newVal, oldVal){
    this.showMask = newVal;   // 監(jiān)測(cè)value的變化,并賦值。
  },
  showMask(val) {
    this.$emit('input', val);  // 此處監(jiān)測(cè)showMask目的為關(guān)閉彈窗時(shí),重新更換value值,注意emit的事件一定要為input。
  }
},

而要想關(guān)閉彈窗,只需要定義一個(gè)方法:

closeMask(){
  this.showMask = false;
},

此刻已經(jīng)可以實(shí)現(xiàn)彈窗的顯示與退出。

下面我們要實(shí)現(xiàn)的是動(dòng)態(tài)添加標(biāo)題,內(nèi)容等,在組件標(biāo)簽中加入title,content:

<dialog-bar title="我是標(biāo)題" content="我是內(nèi)容"></dialog-bar>

可以運(yùn)用vue的數(shù)據(jù)雙向綁定,更換title,content。

在dialog.vue中獲取內(nèi)容:

props: {
value: {},
  content: {
    type: String,
    default: ''
  },
  title: {
    type: String,
    default: ''
  },
},

<div class="dialog-title">{{title}}</div>
<div class="content" v-html="content"></div>

我們可以運(yùn)用同樣的原理來(lái)獲取不同按鈕中的自定名稱。

下面我們利用傳入的不同type來(lái)確定不同的按鈕,并提供不同的回調(diào)函數(shù)。

<dialog-bar title="我是標(biāo)題" content="我是內(nèi)容" type="danger" dangerText="這是刪除按鈕"></dialog-bar>

如傳入type為danger,我們可以在dialog.vue中props獲取type,并定義一個(gè)如下按鈕:

<div v-if="type == 'danger'" class="danger-btn" @click="dangerBtn">
  {{dangerText}}
</div>

dangerBtn(){
  this.$emit('danger');  // 發(fā)送一個(gè)danger事件作為回調(diào)函數(shù)
  this.closeMask();  // 關(guān)閉彈窗
},

在標(biāo)簽中定義danger的回調(diào)并做一些操作:

<dialog-bar title="我是標(biāo)題" content="我是內(nèi)容" type="danger" dangerText="這是刪除按鈕" @danger="clickDanger()"></dialog-bar>

clickDanger(){
  console.log("這里是回調(diào)函數(shù)")
},

同樣原理可以獲取和增添一些其他的操作:

 props: {
    value: {},
    // 類型包括 defalut 默認(rèn), danger 危險(xiǎn), confirm 確認(rèn),
    type:{
      type: String,
      default: 'default'
    },
    content: {
      type: String,
      default: ''
    },
    title: {
      type: String,
      default: ''
    },
    confirmText: {
      type: String,
      default: '確認(rèn)'
    },
    cancelText: {
      type: String,
      default: '取消'
    },
    dangerText: {
      type: String,
      default: '刪除'
    },
  },

<div class="btns">
  <div v-if="type != 'confirm'" class="default-btn" @click="closeBtn">
    {{cancelText}}
  </div>
  <div v-if="type == 'danger'" class="danger-btn" @click="dangerBtn">
    {{dangerText}}
  </div>
  <div v-if="type == 'confirm'" class="confirm-btn" @click="confirmBtn">
    {{confirmText}}
  </div>
</div>

點(diǎn)擊此處去github下載彈窗代碼: https://github.com/wwjhzc/vue-dialog

總結(jié)

以上所述是小編給大家介紹的使用vue實(shí)現(xiàn)各類彈出框組件,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • 關(guān)于antd中select搜索框改變搜索值的問(wèn)題

    關(guān)于antd中select搜索框改變搜索值的問(wèn)題

    這篇文章主要介紹了關(guān)于antd中select搜索框改變搜索值的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue中利用pinyin-pro純前端實(shí)現(xiàn)拼音的模糊搜索功能

    vue中利用pinyin-pro純前端實(shí)現(xiàn)拼音的模糊搜索功能

    這篇文章主要介紹了vue中利用pinyin-pro純前端實(shí)現(xiàn)拼音的模糊搜索,實(shí)現(xiàn)思路很簡(jiǎn)單,通過(guò)安裝配置插件編寫工具類,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue判斷內(nèi)容是否滑動(dòng)到底部的三種方式

    vue判斷內(nèi)容是否滑動(dòng)到底部的三種方式

    這篇文章主要介紹了vue判斷內(nèi)容是否滑動(dòng)到底部的三種方式,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-04-04
  • python虛擬環(huán)境 virtualenv的簡(jiǎn)單使用

    python虛擬環(huán)境 virtualenv的簡(jiǎn)單使用

    virtualenv是一個(gè)創(chuàng)建隔絕的Python環(huán)境的工具。這篇文章主要介紹了python虛擬環(huán)境 virtualenv的簡(jiǎn)單使用,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-01
  • axios二次封裝的詳細(xì)過(guò)程與跨域問(wèn)題

    axios二次封裝的詳細(xì)過(guò)程與跨域問(wèn)題

    通常我們的項(xiàng)目會(huì)越做越大,頁(yè)面也會(huì)越來(lái)越多,隨之而來(lái)的是接口數(shù)量的增加,api統(tǒng)一管理,不管接口有多少,所有的接口都可以非常清晰,容易維護(hù),下面這篇文章主要給大家介紹了關(guān)于axios二次封裝的詳細(xì)過(guò)程與跨域問(wèn)題的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • hansontable在vue中的基本使用教程

    hansontable在vue中的基本使用教程

    handsontable是目前在前端界最接近excel的插件,可以執(zhí)行編輯,復(fù)制粘貼,插入刪除行列,排序等復(fù)雜操作,這篇文章主要介紹了hansontable在vue中的基本使用,需要的朋友可以參考下
    2022-10-10
  • vue學(xué)習(xí)筆記之v-if和v-show的區(qū)別

    vue學(xué)習(xí)筆記之v-if和v-show的區(qū)別

    本篇文章主要介紹了vue學(xué)習(xí)筆記之v-if和v-show的區(qū)別,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • vue-cli初始化項(xiàng)目中使用less的方法

    vue-cli初始化項(xiàng)目中使用less的方法

    vue-cli 是 vue.js 的腳手架工具,可以幫助我們編寫基礎(chǔ)代碼、快速搭建開(kāi)發(fā)環(huán)境。下面這篇文章主要給大家介紹了關(guān)于vue-cli初始化項(xiàng)目中使用less的相關(guān)資料,需要的朋友可以參考借鑒,下面隨著小編來(lái)一起看看吧
    2018-08-08
  • vue+eslint+vscode配置教程

    vue+eslint+vscode配置教程

    這篇文章主要介紹了vue+eslint+vscode配置教程,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-08-08
  • vue實(shí)現(xiàn)搜索并高亮文字的兩種方式總結(jié)

    vue實(shí)現(xiàn)搜索并高亮文字的兩種方式總結(jié)

    在做文字處理的項(xiàng)目時(shí)經(jīng)常會(huì)遇到搜索文字并高亮的需求,常見(jiàn)的實(shí)現(xiàn)方式有插入標(biāo)簽和貼標(biāo)簽兩種,這兩種方式適用于不同的場(chǎng)景,各有優(yōu)劣,下面我們就來(lái)看看他們的具體實(shí)現(xiàn)吧
    2023-11-11

最新評(píng)論