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

亚连
Libérer: 2018-06-07 17:31:59
original
3598 Les gens l'ont consulté

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal