Table des matières
原生alert的缺点
css
开发vue组件
vue template
{{ title }} " > {{ title }}
vue data
vue methods
hack代码
加入一些动画效果
用法
Maison interface Web tutoriel HTML vue一步步实现alert功能。_html/css_WEB-ITnose

vue一步步实现alert功能。_html/css_WEB-ITnose

Jun 21, 2016 am 08:46 AM

原生alert的缺点

  1. 会阻塞一切操作,影响用户体验

  2. 很多浏览器会默认静止alert,例如微信。

  3. 原生alert框样式丑陋。

demo地址: 用力点我

项目地址: web-style 希望大家多多关注。项目里有css样式和vue组件。目标是快速构建后台系统。有一定自适应的设计。

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;   }}
Copier après la connexion

其中 modal-confirm 是alert框,有固定的宽度400px 还有padding。 然后我们做了一个小小的自适应。 在小屏上(屏幕宽度小于640px)取消了固定宽度。减少了padding的值,看起来更小巧。

开发vue组件

vue template

首先我希望这个组件功能能像原生的alert事件一样随时随地的方便调用。 不希望每次都 new Vue({}) 一个实例。 所以我做了一些不一样的设计。

<div class="modal-mask" v-show="show">        <div class="modal-confirm">            <h2 id="i-class-iconfont-icon-questioncircle-i-title">                <i class="iconfont icon-questioncircle"></i> {{ title }}            </h2>            <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>
Copier après la connexion

v-show 是控制alert组件的显示和隐藏的指令。 {{ }} 是vue默认的模版标记。

@click 是绑定click事件的指令

vue data

new Vue({    el: '#V-confirm',    data: {              show: false,              onCancel: false,              onOk: false,              title: '',              content: ''          }    })
Copier après la connexion
  • show 是控制显示隐藏的标记。

  • onCancel onOk 是点击取消或者确定时候触发的回调。

  • 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'      }    }  }
Copier après la connexion

alert(setting) 方法是控制显示alert组件的方法。接受一个object的参数配置。

op(type) 方法是点击取消和确定按钮的时候触发的时候。

hack代码

  var element = document.createElement('div');  element.id = 'V-confirm'  element.innerHTML = template  document.body.appendChild(element)
Copier après la connexion

这一段代码作用是一开始就把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;}
Copier après la connexion

用法

var setting = {}    setting.title = '你确定删除吗?'    setting.content = '删除不可以恢复...'    setting.onOk = function(){}    setting.onCancel = function(){}        $confirm.alert(setting)
Copier après la connexion
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

HTML est-il facile à apprendre pour les débutants? HTML est-il facile à apprendre pour les débutants? Apr 07, 2025 am 12:11 AM

HTML convient aux débutants car il est simple et facile à apprendre et peut rapidement voir les résultats. 1) La courbe d'apprentissage de HTML est fluide et facile à démarrer. 2) Il suffit de maîtriser les balises de base pour commencer à créer des pages Web. 3) Flexibilité élevée et peut être utilisée en combinaison avec CSS et JavaScript. 4) Les ressources d'apprentissage riches et les outils modernes soutiennent le processus d'apprentissage.

Les rôles de HTML, CSS et JavaScript: responsabilités de base Les rôles de HTML, CSS et JavaScript: responsabilités de base Apr 08, 2025 pm 07:05 PM

HTML définit la structure Web, CSS est responsable du style et de la mise en page, et JavaScript donne une interaction dynamique. Les trois exercent leurs fonctions dans le développement Web et construisent conjointement un site Web coloré.

Quel est un exemple d'une balise de départ dans HTML? Quel est un exemple d'une balise de départ dans HTML? Apr 06, 2025 am 12:04 AM

Anexampleofastartingtaginhtmlis, qui abinginsaparagraph.startingtagsaressentialtinhtmlastheyinitiateelements, définit les éventualités, et la faculté de réduction des pages et de la construction de la création.

Comprendre HTML, CSS et JavaScript: un guide pour débutant Comprendre HTML, CSS et JavaScript: un guide pour débutant Apr 12, 2025 am 12:02 AM

WebDevelopmentReliesOnHTML, CSS, etjavascript: 1) HTMLSTRUCTURESCONTENT, 2) CSSSTYLESIT, et3) JavascriptAdddsInterActivity, Forming TheasisofmodernweBEBExperiences.

Comment implémenter la disposition adaptative de la position de l'axe y dans l'annotation Web? Comment implémenter la disposition adaptative de la position de l'axe y dans l'annotation Web? Apr 04, 2025 pm 11:30 PM

L'algorithme adaptatif de la position de l'axe y pour la fonction d'annotation Web Cet article explorera comment implémenter des fonctions d'annotation similaires aux documents de mots, en particulier comment gérer l'intervalle entre les annotations ...

Gitee Pages STATIQUE Le déploiement du site Web a échoué: comment dépanner et résoudre les erreurs de fichier unique 404? Gitee Pages STATIQUE Le déploiement du site Web a échoué: comment dépanner et résoudre les erreurs de fichier unique 404? Apr 04, 2025 pm 11:54 PM

GiteEpages STATIQUE Le déploiement du site Web a échoué: 404 Dépannage des erreurs et résolution lors de l'utilisation de Gitee ...

Comment utiliser CSS3 et JavaScript pour réaliser l'effet de la diffusion et de l'agrandissement des images environnantes après avoir cliqué? Comment utiliser CSS3 et JavaScript pour réaliser l'effet de la diffusion et de l'agrandissement des images environnantes après avoir cliqué? Apr 05, 2025 am 06:15 AM

Pour obtenir l'effet de la diffusion et de l'élargissement des images environnantes après avoir cliqué sur l'image, de nombreuses conceptions Web doivent obtenir un effet interactif: cliquez sur une certaine image pour faire les environs ...

HTML, CSS et JavaScript: outils essentiels pour les développeurs Web HTML, CSS et JavaScript: outils essentiels pour les développeurs Web Apr 09, 2025 am 12:12 AM

HTML, CSS et JavaScript sont les trois piliers du développement Web. 1. HTML définit la structure de la page Web et utilise des balises telles que, etc. 2. CSS contrôle le style de page Web, en utilisant des sélecteurs et des attributs tels que la couleur, la taille de la police, etc. 3. JavaScript réalise les effets dynamiques et l'interaction, par la surveillance des événements et les opérations DOM.

See all articles