Maison interface Web js tutoriel Comment implémenter un composant de barre de progression sensible aux événements dans Vue

Comment implémenter un composant de barre de progression sensible aux événements dans Vue

Jun 07, 2018 pm 05:31 PM
vue 组件

Cet article présente principalement l'exemple de code du composant de barre de progression sensible aux événements de Vue. Il est très bon et a une valeur de référence. Les amis qui en ont besoin peuvent s'y référer

Écrivez-le. devant

J'ai trouvé beaucoup de composants de barre de progression de vue, dont aucun n'inclut des événements de glisser-cliquer. La plage d'entrée contient nativement des événements d'entrée et de modification, mais si vous créez une barre de progression. Directement basé sur la plage d'entrée, le style Certaines parties nécessitent de nombreux ajustements et traitements de compatibilité. Même si cela est fait, si l'apparence doit être modifiée à l'avenir, cela posera beaucoup de problèmes.

Sur la base des deux raisons ci-dessus, nous avons créé un système capable de répondre aux événements de saisie et de modification (c'est-à-dire que l'une consiste à faire glisser la barre de progression quelque part et l'autre à cliquer sur une certaine position du barre de progression pour changer sa valeur à cette position) Le composant Vue implémenté par p répond non seulement à la demande d'événements de barre de progression, mais apporte également l'avantage d'une modification de style pratique si les exigences changent.

Rendu

Ceux-ci ci-dessus sont quelques-uns des effets qui peuvent être obtenus à l'aide de ce composant. Ils peuvent répondre à la fois aux événements d'entrée et de changement.

La première partie est la partie modèle

Regardez attentivement l'image ci-dessus. Comment construire le modèle HTML doit encore être réfléchi. Je l'ai également modifié plusieurs fois et j'ai finalement réglé. sur celle-ci. Tout d’abord, il y a une couche d’externalisation dont je ne parlerai pas. Ensuite, il y a un p avec class = 'progress' sous le p d'externalisation. Le p à l'intérieur de ce p signifie que la barre de progression a traversé la pièce (class="left") Le p avec class="left" contient également un p indiquant que. La boule coulissante que l'on peut faire glisser.

Laissez-moi parler des avantages. Avec ce genre de structure et de style, lorsque vous vérifiez les éléments sur la page, vous pouvez clairement voir que chaque p chevauche la partie affichée sur la page.

Si votre barre de progression représente p sur toute la longueur, p représente la moitié gauche et p représente le curseur, ce n'est pas une structure imbriquée comme la mienne, mais une relation de nœud frère, vous devez utiliser des styles pour faites Position relative et déplacez les deux derniers nœuds frères vers le haut, de sorte que lorsque l'élément est coché, les cases des autres composants situées sous la barre de progression pénètrent dans la zone de la barre de progression. Bien que l'utilisateur ne vérifie pas les éléments, il ne sera pas pratique pour les programmeurs de les observer par eux-mêmes après une longue période, n'est-ce pas ?

En d'autres termes, nous espérons tous que les éléments exprimés par la structure HTML et l'espace réservé de chaque élément affiché lors de l'inspection de l'élément sont cohérents. Cela peut également être considéré comme un indicateur d’évaluation pour savoir si votre structure HTML est raisonnablement construite.

<template>
 <p class="progress-wrapper" :style="wrapStyle">
  <p class="progress" @mousedown="mousedownHandler" @mouseover="mouseoverHandler"
    @mousemove="mousemoveHandler" @mouseup="mouseupHandler" :style="pBarStyle">
   <p class="left" :style="leftStyle">
    <p class="ball" :style="ballStyle"></p>
   </p>
   <slot></slot>
  </p>
 </p>
</template>
Copier après la connexion

partie js

Pour les étudiants qui ont besoin d'utiliser cette barre de progression avec des événements maintenant, jetez un œil à cette partie pour vous aider à la modifier vous-même, parfait il.

Pour les étudiants qui souhaitent essayer ce composant en premier, vous pouvez sauter la lecture de cette partie. Lorsque vous constatez que le composant n'est pas assez fonctionnel, il ne sera pas trop tard pour regarder cette partie du code.

export default {
  name: &#39;ProgressBar&#39;,
  props: {
   leftBg: String,
   bgc: String,
   ballBgc: String,
   height: String,
   width: String,
   max: {
    type: Number,
    default: 100,
   },
   min: {
    type: Number,
    default: 0,
   },
   value: {
    type: Number,
    default: 36,
   },
  },
  data: function () {
   return {
    pValue: this.value,
    pMax: this.max,
    pMin: this.min,
    wrapStyle: {
     &#39;width&#39;: this.width,
    },
    pBarStyle: {
     &#39;backgroundColor&#39;: this.bgc,
     &#39;height&#39;: this.height,
    },
    leftStyle: {
     &#39;width&#39;: this.progressPercent + &#39;%&#39;,
     &#39;background&#39;: this.leftBg,
     &#39;height&#39;: this.height,
    },
    ballStyle: {
     &#39;backgroundColor&#39;: this.ballBgc,
     &#39;height&#39;: this.height,
     &#39;width&#39;: this.height,
     &#39;borderRadius&#39;: parseInt(this.height) / 2 + &#39;px&#39;,
     &#39;right&#39;: - parseInt(this.height) / 2 + &#39;px&#39;,
    },
    // 标记是否按下鼠标
    isMouseDownOnBall: false,
   }
  },
  computed: {
   progressPercent(){
    return (this.pValue - this.pMin) / (this.pMax - this.pMin) * 100;
   },
   progressElement(){
    return this.$el.getElementsByClassName(&#39;progress&#39;)[0];
   },
  },
  methods: {
   mousedownHandler(e){
    if(e.which === 1){
     this.isMouseDownOnBall = true;
    }
   },
   mousemoveHandler(e){
    if(this.isMouseDownOnBall === true){
     // 修改进度条本身
     let decimal = (e.clientX - this.$el.offsetLeft) / this.progressElement.clientWidth;
     let percent = decimal * 100;
     this.leftStyle.width = percent + &#39;%&#39;;
     // 修改value
     this.pValue = this.pMin + decimal * (this.pMax - this.pMin);
     this.$emit(&#39;pbar-drag&#39;, this.pValue, percent);
    }
   },
   mouseupHandler(e){
    if(this.isMouseDownOnBall){
     // 修改进度条本身
     let decimal = (e.clientX - this.$el.offsetLeft) / this.progressElement.clientWidth;
     let percent = decimal * 100;
     this.leftStyle.width = percent + &#39;%&#39;;
     // 修改value
     this.pValue = this.pMin + decimal * (this.pMax - this.pMin);
     this.$emit(&#39;pbar-seek&#39;, this.pValue, percent);
     this.isMouseDownOnBall = false;
    }
   },
   mouseoverHandler(e){
    // 没有按左键进入进度条
    if(e.which === 0){
     this.isMouseDownOnBall = false;
    }
   }
  },
  watch: {
   max(cur, old){
    this.pMax = cur;
   },
   min(cur, old){
    this.pMin = cur;
   },
   value(cur, old){
    this.pValue = cur;
   },
   progressPercent(cur, old){
    this.leftStyle.width = cur + &#39;%&#39;;
   }
  },
  mounted(){
   // 数据验证
   if(this.max < this.min){
    console.error("max can&#39;t less than min !");
   }
   // 初始百分比
   this.leftStyle.width = (this.pValue - this.pMin) / (this.pMax - this.pMin) * 100 + &#39;%&#39;;
  },
 }
Copier après la connexion

Installer et utiliser

Adresse

L'adresse de la base de code est sur GitHub

Installer et utiliser

npm install vue-draggable-progressbar --save
import progressBar from &#39;vue-draggable-progressbar&#39;
Copier après la connexion

Cas d'utilisation :

<progress-bar ref="aa"></progress-bar>
<progress-bar width="40%" leftBg="greenyellow" bgc="#ccc" ballBgc="red"></progress-bar>
<progress-bar width="60%" leftBg="linear-gradient(to right, yellow, pink)" bgc="#ccc" ballBgc="red"></progress-bar>
<progress-bar width="80%" leftBg="yellow" bgc="#ccc" ballBgc="red" height="30px"></progress-bar>
<progress-bar leftBg="greenyellow" bgc="#ccc" ballBgc="rgba(255,0,0,0.2)" height="40px"></progress-bar>
<progress-bar leftBg="greenyellow" bgc="#ccc" ballBgc="red" :max="max" :value="value" :min="min"
    @pbar-drag="drag" @pbar-seek="seek"></progress-bar>
Copier après la connexion

accessoires de composants

  • leftBg : La barre de progression a traversé une partie de la couleur d'arrière-plan

  • bgc : La barre de progression n'a pas traversé une partie de la couleur d'arrière-plan

  • ballBgc : Couleur d'arrière-plan du curseur

  • largeur : le pourcentage de la largeur de la barre de progression dans le composant parent, transmettre la valeur en pourcentage

  • hauteur : la hauteur de la barre de progression, passer la valeur des pixels

  • max : valeur maximale de la barre de progression

  • min : minimum valeur

  • valeur : valeur actuelle

Événement

  • pbar-drag : Déclenché lors du déplacement de la barre de progression, renvoie la valeur et le pourcentage de réussite

  • pbar-drag : Déclenché lorsqu'une certaine position de la barre de progression est cliquée, renvoie la valeur et pourcentage

Ce qui précède est ce que j'ai compilé pour tout le monde. J'espère que cela sera utile à tout le monde à l'avenir.

Articles associés :

Comment utiliser les éléments Dom dans jQuery ?

Quelles sont les fonctions de tableau couramment utilisées en js ?

À propos de l'utilisation de Datepicker dans vue2.0

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.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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 utiliser Watch in Vue Comment utiliser Watch in Vue Apr 07, 2025 pm 11:36 PM

L'option Watch dans Vue.js permet aux développeurs d'écouter des modifications de données spécifiques. Lorsque les données changent, regardez déclenche une fonction de rappel pour effectuer des vues de mise à jour ou d'autres tâches. Ses options de configuration incluent immédiatement, qui spécifie s'il faut exécuter un rappel immédiatement, et profond, ce qui spécifie s'il faut écouter récursivement les modifications des objets ou des tableaux.

Comment référencer le fichier JS avec Vue.js Comment référencer le fichier JS avec Vue.js Apr 07, 2025 pm 11:27 PM

Il existe trois façons de se référer aux fichiers JS dans Vue.js: spécifiez directement le chemin à l'aide du & lt; script & gt; étiqueter;; importation dynamique à l'aide du crochet de cycle de vie monté (); et l'importation via la bibliothèque de gestion de l'État Vuex.

Comment utiliser Bootstrap en Vue Comment utiliser Bootstrap en Vue Apr 07, 2025 pm 11:33 PM

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Comment ajouter des fonctions aux boutons pour Vue Comment ajouter des fonctions aux boutons pour Vue Apr 08, 2025 am 08:51 AM

Vous pouvez ajouter une fonction au bouton VUE en liant le bouton dans le modèle HTML à une méthode. Définissez la logique de la fonction de méthode et d'écriture dans l'instance Vue.

Comment revenir à la page précédente par Vue Comment revenir à la page précédente par Vue Apr 07, 2025 pm 11:30 PM

Vue.js dispose de quatre méthodes pour revenir à la page précédente: $ router.go (-1) $ router.back () utilise & lt; router-link to = & quot; / & quot; Composant Window.History.back (), et la sélection de la méthode dépend de la scène.

Vue réalise l'effet de défilement de chapiteau / texte Vue réalise l'effet de défilement de chapiteau / texte Apr 07, 2025 pm 10:51 PM

Implémentez les effets de défilement marquee / texte dans VUE, en utilisant des animations CSS ou des bibliothèques tierces. Cet article présente comment utiliser l'animation CSS: créer du texte de défilement et envelopper du texte avec & lt; div & gt;. Définissez les animations CSS et défini: caché, largeur et animation. Définissez les images clés, Set Transforment: Translatex () au début et à la fin de l'animation. Ajustez les propriétés d'animation telles que la durée, la vitesse de défilement et la direction.

Que signifie la charge paresseuse? Que signifie la charge paresseuse? Apr 07, 2025 pm 11:54 PM

Dans vue.js, le chargement paresseux permet de charger dynamiquement les composants ou les ressources, en réduisant le temps de chargement des pages initiales et en améliorant les performances. La méthode de mise en œuvre spécifique comprend l'utilisation de & lt; keep-alive & gt; et & lt; composant est & gt; composants. Il convient de noter que le chargement paresseux peut provoquer des problèmes de FOUC (écran d'éclat) et ne doit être utilisé que pour les composants qui nécessitent un chargement paresseux pour éviter les frais généraux de performances inutiles.

Comment interroger la version de Vue Comment interroger la version de Vue Apr 07, 2025 pm 11:24 PM

Vous pouvez interroger la version Vue en utilisant Vue Devtools pour afficher l'onglet Vue dans la console du navigateur. Utilisez NPM pour exécuter la commande "NPM List -g Vue". Recherchez l'élément VUE dans l'objet "dépendances" du fichier package.json. Pour les projets Vue CLI, exécutez la commande "Vue --version". Vérifiez les informations de la version dans le & lt; script & gt; Tag dans le fichier html qui fait référence au fichier VUE.

See all articles