Maison interface Web js tutoriel Vue implémente le bouton de compte à rebours

Vue implémente le bouton de compte à rebours

Apr 27, 2018 pm 03:40 PM
倒计时 实现 按钮

Cette fois, je vais vous expliquer comment implémenter un bouton de compte à rebours dans Vue. Quelles sont les précautions pour implémenter un bouton de compte à rebours dans Vue. Voici un cas pratique, jetons un oeil.

Dans le développement de projets, nous rencontrons souvent des boutons qui envoient des codes de vérification et ont un compte à rebours de 60 secondes après avoir cliqué. C'est très courant mais aussi très simple, mais lors de l'écriture de ce bouton, il y en a. certains endroits auxquels je dois faire attention. Je les écrirai aujourd'hui. S'il y a des questions, corrigez-moi !

L'effet complété est le suivant :

Afin d'afficher l'effet plus rapidement, j'ai réglé le temps à 5 secondes. Après avoir cliqué sur le bouton, un compte à rebours apparaîtra. Dans le même temps, le bouton deviendra non cliquable, son style changera également et l'apparence du survol de la souris changera également.

Ensuite, nous utilisons du code pour l'implémenter :

<button class="button" @click="countDown">
 {{content}}
</button>
...
data () {
  return {
   content: '发送验证码',  // 按钮里显示的内容
   totalTime: 60      //记录具体倒计时时间
  }
},
methods: {
  countDown() {
    let clock = window.setInterval(() => {
      this.total--
      this.content = this.total + 's后重新发送'
    },1000)
  }
}
Copier après la connexion

Ajoutez deux éléments de données aux données, un pour enregistrer l'heure et un pour contenir le contenu spécifique du bouton de compte à rebours. Dans la fonction countDown, nous utilisons la minuterie setInterval pour décrémenter le totalTime de 1 chaque seconde et modifier le contenu affiché dans le bouton. La fonction de flèche est utilisée dans window.setInterval car elle liera automatiquement le this externe, il n'est donc pas nécessaire de l'enregistrer au préalable.

L'effet est le suivant :

Mais il y a encore quelques problèmes avec ce bouton :

Après 1 seconde après avoir cliqué sur le bouton , ça ira directement de Le compte à rebours commence à 59 secondes, et il manque le 60 au milieu
Vous pouvez aussi cliquer pendant le compte à rebours
Le compte à rebours n'a pas encore été effacé

Ensuite, vous Nous devons continuer à améliorer la fonction de compte à rebours pour résoudre ces problèmes.

countDown () {
 this.content = this.totalTime + 's后重新发送' //这里解决60秒不见了的问题
 let clock = window.setInterval(() => {
  this.totalTime--
  this.content = this.totalTime + 's后重新发送'
  if (this.totalTime < 0) {     //当倒计时小于0时清除定时器
    window.clearInterval(clock)
    this.content = &#39;重新发送验证码&#39;
    this.totalTime = 60
    }
 },1000)
},
Copier après la connexion

Le code ci-dessus résout le problème des 60 manquants. En même temps, lorsque totalTime est inférieur à 0, il efface le synchroniseur, réinitialise le contenu du bouton et réinitialise totalTime à 60 pour la prochaine fois. utilisation du temps.

L'effet du compte à rebours de 10 secondes :

J'ai trouvé un bug après avoir cliqué plusieurs fois, la vitesse de rembobinage devient plus rapide. cliquez pour démarrer un setInterval, ces setIntervals réduiront totalTime. La solution est également très simple : il suffit de la limiter, c'est-à-dire de rendre le code de la fonction countDonw non exécutable après le premier clic sur le bouton, et d'attendre la fin du compte à rebours avant de pouvoir l'exécuter à nouveau.

data () {
  return {
   content: &#39;发送验证码&#39;,
   totalTime: 10,
   canClick: true //添加canClick
  }
}
...
countDown () {
 if (!this.canClick) return  //改动的是这两行代码
 this.canClick = false
 this.content = this.totalTime + &#39;s后重新发送&#39;
 let clock = window.setInterval(() => {
  this.totalTime--
  this.content = this.totalTime + 's后重新发送'
  if (this.totalTime < 0) {
   window.clearInterval(clock)
   this.content = &#39;重新发送验证码&#39;
   this.totalTime = 10
   this.canClick = true  //这里重新开启
  }
 },1000)
}
Copier après la connexion

Ajouter canClick dans les données. La valeur par défaut est true Si canClick est vrai, le code dans countDown peut être exécuté. S'il est faux, cela ne fonctionnera pas. Définissez canClick sur false à chaque fois qu'il est exécuté et ne le changez en true qu'à la fin du compte à rebours. De cette façon, le problème disparaît maintenant.

C'est presque terminé ici, mais vous pouvez également ajuster le style :

<button class="button" :class="{disabled: !this.canClick}" @click="countDown">
...
.disabled{
 background-color: #ddd;
 border-color: #ddd;
 color:#57a3f3;
 cursor: not-allowed; // 鼠标变化
}
Copier après la connexion

Effet :

Ce bouton de compte à rebours est très simple, mais il était encore très compliqué lorsque je l'ai écrit pour la première fois, et je ne connaissais pas le concept de limitation de fonctions à cette époque.

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture recommandée :

Explication détaillée de l'utilisation du modificateur .sync de vue

jQuery$ et $(). .utilisez Explication détaillée

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

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)

Comment mettre en œuvre la double connexion WeChat sur les téléphones mobiles Huawei ? Comment mettre en œuvre la double connexion WeChat sur les téléphones mobiles Huawei ? Mar 24, 2024 am 11:27 AM

Comment mettre en œuvre la double connexion WeChat sur les téléphones mobiles Huawei ? Avec l’essor des réseaux sociaux, WeChat est devenu l’un des outils de communication indispensables dans la vie quotidienne des gens. Cependant, de nombreuses personnes peuvent rencontrer un problème : se connecter à plusieurs comptes WeChat en même temps sur le même téléphone mobile. Pour les utilisateurs de téléphones mobiles Huawei, il n'est pas difficile d'obtenir une double connexion WeChat. Cet article explique comment obtenir une double connexion WeChat sur les téléphones mobiles Huawei. Tout d'abord, le système EMUI fourni avec les téléphones mobiles Huawei offre une fonction très pratique : l'ouverture d'une double application. Grâce à la fonction de double ouverture de l'application, les utilisateurs peuvent simultanément

Pourquoi mon ordinateur portable ne démarre-t-il pas après avoir appuyé sur le bouton d'alimentation ? Pourquoi mon ordinateur portable ne démarre-t-il pas après avoir appuyé sur le bouton d'alimentation ? Mar 10, 2024 am 09:31 AM

Il peut y avoir plusieurs raisons pour lesquelles votre ordinateur portable Windows ne démarre pas. Une panne de mémoire, une batterie déchargée, un bouton d'alimentation défectueux ou des problèmes matériels sont autant de causes courantes. Voici quelques solutions pour vous aider à résoudre ce problème. L'ordinateur portable ne s'allume pas après avoir appuyé sur le bouton d'alimentation Si votre ordinateur portable Windows ne s'allume toujours pas après avoir appuyé sur le bouton d'alimentation, voici quelques étapes que vous pouvez suivre pour résoudre le problème : Votre ordinateur portable est-il complètement chargé ? Effectuez une réinitialisation matérielle pour nettoyer votre ordinateur portable Réinstallez la mémoire Batterie de type CMOS transparente Emmenez votre ordinateur portable en réparation. 1] Votre ordinateur portable est-il complètement chargé ? La première chose à faire est de vérifier si votre ordinateur portable est complètement chargé. L'ordinateur portable ne démarre pas si la batterie est épuisée

Guide de programmation PHP : méthodes pour implémenter la séquence de Fibonacci Guide de programmation PHP : méthodes pour implémenter la séquence de Fibonacci Mar 20, 2024 pm 04:54 PM

Le langage de programmation PHP est un outil puissant pour le développement Web, capable de prendre en charge une variété de logiques et d'algorithmes de programmation différents. Parmi eux, l’implémentation de la séquence de Fibonacci est un problème de programmation courant et classique. Dans cet article, nous présenterons comment utiliser le langage de programmation PHP pour implémenter la séquence de Fibonacci et joindrons des exemples de code spécifiques. La suite de Fibonacci est une suite mathématique définie comme suit : le premier et le deuxième élément de la suite valent 1, et à partir du troisième élément, la valeur de chaque élément est égale à la somme des deux éléments précédents. Les premiers éléments de la séquence

À quoi ressemble l'iPhone 16 ? Quels changements y a-t-il dans l'iPhone 16 ? À quoi ressemble l'iPhone 16 ? Quels changements y a-t-il dans l'iPhone 16 ? Apr 07, 2024 pm 05:10 PM

Après la sortie de la série iPhone 15, les révélations ont été constantes sur l’apparence et la configuration du nouvel iPhone 16 d’Apple. À quoi ressemble l’iPhone 16 ? Y a-t-il une amélioration dans l’iPhone 16 ? Récemment, un blogueur étranger a présenté le design de la série iPhone 16. La conception globale est fondamentalement la même que celle de la série iPhone 15. Comme vous pouvez le voir sur la photo, toute la série iPhone 16 est équipée en standard d'un nouveau bouton « prise de vue », permettant aux utilisateurs de prendre des photos plus facilement. De plus, d’autres détails de conception sont encore inconnus. Le message indique que ce nouveau bouton sera utilisé pour filmer des vidéos et se situe sous le bouton d'alimentation. Des informations précédentes mentionnaient qu'il pourrait s'agir d'un bouton à semi-conducteurs capacitif, mais des rapports récents indiquent qu'il devrait toujours s'agir d'un bouton à semi-conducteurs capacitif.

Comment implémenter la fonction de clonage WeChat sur les téléphones mobiles Huawei Comment implémenter la fonction de clonage WeChat sur les téléphones mobiles Huawei Mar 24, 2024 pm 06:03 PM

Comment mettre en œuvre la fonction de clonage WeChat sur les téléphones mobiles Huawei Avec la popularité des logiciels sociaux et l'importance croissante accordée à la confidentialité et à la sécurité, la fonction de clonage WeChat est progressivement devenue le centre d'attention. La fonction de clonage WeChat peut aider les utilisateurs à se connecter simultanément à plusieurs comptes WeChat sur le même téléphone mobile, ce qui facilite la gestion et l'utilisation. Il n'est pas difficile de mettre en œuvre la fonction de clonage WeChat sur les téléphones mobiles Huawei. Il vous suffit de suivre les étapes suivantes. Étape 1 : Assurez-vous que la version du système de téléphonie mobile et la version de WeChat répondent aux exigences. Tout d'abord, assurez-vous que la version de votre système de téléphonie mobile Huawei a été mise à jour vers la dernière version, ainsi que l'application WeChat.

Comment résoudre le problème des boutons qui ne répondent pas dans le navigateur IE Comment résoudre le problème des boutons qui ne répondent pas dans le navigateur IE Jan 30, 2024 am 10:48 AM

Que dois-je faire s'il n'y a pas de réponse lorsque le navigateur IE clique sur le bouton Web ? S'il n'y a pas de réponse lorsque nous cliquons sur le bouton Web, nous pouvons le définir dans la vue de compatibilité ! Lorsque certains amis utilisent le navigateur IE, ils constatent que le navigateur ne répond pas lorsqu'ils cliquent sur le bouton de la page Web. De cette façon, nous ne pouvons pas utiliser les fonctions de la page Web. Comment pouvons-nous le configurer ? compilé le navigateur IE ci-dessous. Comment résoudre le problème du navigateur qui ne répond pas lorsque vous cliquez sur le bouton Web. Sinon, suivez-moi et continuez à lire ? Le navigateur IE ne répond pas lorsque vous cliquez sur le bouton Web. Solution : 1. Ouvrez le navigateur IE, cliquez sur le bouton [Outils] dans la barre d'opérations, puis cliquez sur les paramètres [Affichage de compatibilité], comme indiqué dans la figure. 2. Dans la page de paramètres [Affichage de compatibilité], cliquez sur le bouton [Ajouter] à droite et remplissez le site Web.

Découvrez comment Golang offre des possibilités de développement de jeux Découvrez comment Golang offre des possibilités de développement de jeux Mar 16, 2024 pm 12:57 PM

Dans le domaine actuel du développement logiciel, Golang (langage Go), en tant que langage de programmation efficace, concis et hautement simultané, est de plus en plus favorisé par les développeurs. Sa riche bibliothèque de normes et ses fonctionnalités de concurrence efficaces en font un choix de premier plan dans le domaine du développement de jeux. Cet article explorera comment utiliser Golang pour le développement de jeux et démontrera ses puissantes possibilités à travers des exemples de code spécifiques. 1. Avantages de Golang dans le développement de jeux. En tant que langage typé statiquement, Golang est utilisé dans la construction de systèmes de jeux à grande échelle.

Guide de mise en œuvre des exigences du jeu PHP Guide de mise en œuvre des exigences du jeu PHP Mar 11, 2024 am 08:45 AM

Guide d'implémentation des exigences du jeu PHP Avec la popularité et le développement d'Internet, le marché des jeux Web devient de plus en plus populaire. De nombreux développeurs espèrent utiliser le langage PHP pour développer leurs propres jeux Web, et la mise en œuvre des exigences du jeu constitue une étape clé. Cet article explique comment utiliser le langage PHP pour implémenter les exigences courantes du jeu et fournit des exemples de code spécifiques. 1. Créer des personnages de jeu Dans les jeux Web, les personnages de jeu sont un élément très important. Nous devons définir les attributs du personnage du jeu, tels que le nom, le niveau, la valeur de l'expérience, etc., et fournir des méthodes pour les exploiter.

See all articles