欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

vue如何實現(xiàn)alert功能

這篇文章主要介紹了vue如何實現(xiàn)alert功能,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)公司是專業(yè)的柘榮網(wǎng)站建設公司,柘榮接單;提供成都網(wǎng)站制作、成都做網(wǎng)站、外貿營銷網(wǎng)站建設,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行柘榮網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

原生alert的缺點

  1. 會阻塞一切操作,影響用戶體驗

  2. 很多瀏覽器會默認靜止alert,例如微信。

  3. 原生alert框樣式丑陋。

vue如何實現(xiàn)alert功能

項目地址: web-style 項目里有css樣式和vue組件。目標是快速構建后臺系統(tǒng)。有一定自適應的設計。

css

思路:最外層是一個黑色透明撐滿全屏幕的div并且是fixed的div.modal-mask。

在mask內部是一個垂直居中的div框大小可以固定。垂直居中方法有幾種可選。我選用的是flex。關鍵性的css代碼如下

.modal-mask{
 position: fixed;
 top: 0;
 left: 0;
 right: 0;
 bottom: 0;
 background-color: rgba(55,55,55,.6);
 z-index: 100;
 display: flex;
 align-items: center;
 justify-content: center;
}
.modal-confirm{
 width: 400px;
 box-sizing: border-box;
 padding: 30px 40px;
 background-color: #fff;
 border-radius: 6px;
}
@media only screen and (max-width: 640px) {
 .modal-confirm{
  width: 100%;
  margin: 0 20px;
  padding: 10px 20px; 
 }
}

其中modal-confirm是alert框,有固定的寬度400px 還有padding。 然后我們做了一個小小的自適應。 在小屏上(屏幕寬度小于640px)取消了固定寬度。減少了padding的值,看起來更小巧。

開發(fā)vue組件

vue template

首先我希望這個組件功能能像原生的alert事件一樣隨時隨地的方便調用。 不希望每次都new Vue({})一個實例。 所以我做了一些不一樣的設計。

<div class="modal-mask" v-show="show">
    <div class="modal-confirm">
      <h3 class="confirm-header">
        <i class="iconfont icon-questioncircle"></i> {{ title }}
      </h3>
      <div class="confirm-content">
        {{ content }}
      </div>
      <div class="confirm-btns">
        <button class="btn" @click="op(1)">取 消</button>
        <button class="btn btn-primary" @click="op(2)">確 定</button>
      </div>
    </div>
  </div>

v-show是控制alert組件的顯示和隱藏的指令。 {{ }}是vue默認的模版標記。

@click 是綁定click事件的指令

vue data

new Vue({
  el: '#V-confirm',
  data: {
       show: false,
       onCancel: false,
       onOk: false,
       title: '',
       content: ''
     }
  })
  1. show 是控制顯示隱藏的標記。

  2. onCancel onOk 是點擊取消或者確定時候觸發(fā)的回調。

  3. title content 是alert顯示的文本。

vue methods

 methods: {
   op(type){
    this.show = false
    if(type == '1'){
     if(this.onCancel) this.onCancel()
    }else{
     if(this.onOk) this.onOk()
    }

    this.onCancel = false
    this.onOk = false
    
    document.body.style.overflow = ''
   },
   alert(setting){
    this.title = setting.title || '標題'
    this.content = setting.content || '內容'
    this.onOk = setting.onOk || false
    this.onCancel = setting.onCancel || false
    this.show = true
    document.body.style.overflow = 'hidden'
   }
  }
 }
  1. alert(setting) 方法是控制顯示alert組件的方法。接受一個object的參數(shù)配置。

  2. op(type) 方法是點擊取消和確定按鈕的時候觸發(fā)的時候。

hack代碼

 var element = document.createElement('div');
 element.id = 'V-confirm'
 element.innerHTML = template
 document.body.appendChild(element)

這一段代碼作用是一開始就把vue實例插入到 body 底部,方便直接 alert 調用。

加入一些動畫效果

依賴的是vue指令 transition 具體的用法教程 大家去過渡-傳送門

.modal-enter, .modal-leave {
 opacity: 0;
}
.modal-transition{
 transition: all .3s ease;
}

.modal-enter .modal-confirm,
.modal-leave .modal-confirm {
 transform: scale(1.1);
}
.modal-transition{
 transition: all .3s ease;
}

用法

var setting = {}
  setting.title = '你確定刪除嗎?'
  setting.content = '刪除不可以恢復...'
  setting.onOk = function(){}
  setting.onCancel = function(){}
  
  
$confirm.alert(setting)

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vue如何實現(xiàn)alert功能”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!

當前名稱:vue如何實現(xiàn)alert功能
文章鏈接:http://aaarwkj.com/article42/goooec.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供關鍵詞優(yōu)化、全網(wǎng)營銷推廣品牌網(wǎng)站設計、網(wǎng)站維護、面包屑導航網(wǎng)站內鏈

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網(wǎng)站制作
亚洲成av人片青草影院| 国产成人大片一区二区三区| 国产传媒网站在线观看| av黄色资源在线观看| 黑人精品一区二区三区| 91精品亚洲内射孕妇| 欧美日韩国产精品高清| 久久这里只有精品热免费| 亚洲黄色av乱码在线观看| 国产欧美日本一区二区| 成年网站在线91九色| 在线日韩中文字幕二区| 五月婷婷丁香六月在线综合| 年轻的母亲韩国三级| 亚洲欧美av中文日韩二区| 亚州精品乱码久久电影| 免费国产成人高清在线视频| 很黄无遮挡在线免费网站| 亚洲国产高清国产拍精品| 一本色道久久亚洲综合精品蜜桃| 99久久久精品国产免费| 91九色中文视频在线观看| 韩国福利短片在线观看| 国产在线不卡免费精品| 国产精品一区二区日韩新区| 精品日韩欧美精品日韩| 97免费在线视频观看| 野花日本免费高清完整| 一区二区三区人妻系列| 中文有码人妻字幕在线| 久久精品国产亚洲av清纯| 爱爱网爱综合日日干夜夜操| 青青草原一区在线观看| 国产欧美日韩综合激情| 欧美日韩一区二区三区久久精品| av中文字幕国产精品| 亚洲一区二区三区在线播| 午夜福利激情视频在线| 青青成线在人线免费啪| 亚洲成人精品久久久| 日本经典三级在线视频|