Maison > interface Web > js tutoriel > le corps du texte

JS encapsule la fonction de fondu d'entrée et de sortie

php中世界最好的语言
Libérer: 2018-06-15 15:12:07
original
1546 Les gens l'ont consulté

Cette fois, je vais vous présenter la fonction de fondu d'entrée et de sortie encapsulée JS Quelles sont les précautions à prendre pour la fonction de fondu d'entrée et de sortie encapsulée JS Ce qui suit est un cas pratique, jetons un coup d'œil.

En ce qui concerne l'affichage du dégradé et la disparition de js, la plupart des amis penseront à fadeIn(), fadeOut() ou fadeToggle() dans JQuery. Mais que se passerait-il si l’immense bibliothèque JQuery était appelée uniquement pour introduire un tel effet ? En d'autres termes, je me suis amélioré en utilisant du js natif pour implémenter certaines fonctions~

Ainsi, j'ai brièvement étudié l'effet de l'écriture de fondus d'entrée et de sortie dans du code js pur.

S'il y a une erreur, merci de me la signaler dans les commentaires afin que je puisse corriger mes propres erreurs

(1 ) FadeIn L'effet de fondu de la fonction

est en fait un setInterval(), couplé à des opérations DOM cycliques, cet effet peut être obtenu en modifiant la transparence du nœud objet de l'élément.

Nous extrayons donc deux choses nécessaires : setInterval(), l'opacité et la vitesse.

  • vitesse : Il s'agit de la vitesse de changement de la valeur flottante lorsque nous définissons la valeur d'opacité de 0 à 1.

  • La logique du fondu entrant : la valeur d'opacité passe de la valeur Float passe de 0 à 1.

html :

<p id="p1"></p>
<span id="span1">123</span>
<button>fadein</button>
<button>fadeOut</button>
Copier après la connexion

style css

<style>
 p {
  width: 100px;
  height: 100px;
  background-color: #1d7db1;
  opacity:0;
 }
 </style>
Copier après la connexion

Tout d'abord, voyons comment écrire la première version de la fonction fadeIn : Comprenons-le d'abord. Idées de mise en œuvre

function fadeIn(ele, speed) {
  let num = 0;
  let time = setInterval(() => {
    num += speed;
    ele.style.opacity = num / 100;
    if (num >= 100) {
     clearInterval(time); // 清楚定时器
    }
  }, 30);
  }
}
Copier après la connexion

Lorsque cet effet est temporairement atteint, certaines choses ne sont pas si simples. Si plusieurs effets de déclenchement se produisent, setInterval sera utilisé plusieurs fois en même temps, provoquant des BUG gênants.

Pour résoudre ce problème, il existe actuellement une solution : ajouter un état global pour éviter que setInterval soit déclenché plusieurs fois.

let Fadeflag = true;
function fadeIn(ele, speed) {
  let num = 0;
  if (Fadeflag) {
  let time = setInterval(() => {
    num += speed;
    Fadeflag = false;
    ele.style.opacity = num / 100;
    if (num >= 100) {
     clearInterval(time);
     Fadeflag = true;
    }
  }, 30);
  }
}
Copier après la connexion

Problème de compatibilité ! ! !

Regardez d'abord le code

set: function(elem, num) {
  elem.style.opacity !== undefined ? elem.style.opacity = num / 100 : elem.style.filter = 'alpha(opacity = '+ num +')';
}
Copier après la connexion

Remarque : le code définit num/100 car nous utilisons ie comme standard pour être compatible avec ff et GG

nœud DOM la transparence est définie dans l'attribut de fonction js : filter= "alpha(opacity=" + value+ ")" (compatible avec ie)

la plage de filtre d'ie est 0~100

opacity=value/100 (compatible avec FF et GG).

L'opacité de FF et GG est de 0~1 (afin d'être compatible avec la plage de filtre, c'est-à-dire, nous utilisons num/100)

(2) Fonction FadeOut

vitesse : Il s'agit de la vitesse à laquelle la valeur flottante change lorsque nous définissons la valeur d'opacité de 1 à 0 (n'oubliez pas de prendre en compte la compatibilité)

FadeOut logique : la valeur d'opacité passe de 1 à 0. La valeur float change.

Fonction d'emballage

(function() {
  let fadeFlag = true;
  function Fade(selector) {
    this.elem = typeof selector == 'Object' ? selector : document.getElementById(selector);
  }
  Fade.prototype = {
   constructor: Fade,
    setOpacity: (elem, opacity) => { // 兼容ie10—
      elem.filters ? elem.style.filter = 'alpha(opacity = '+ opacity +')':  elem.style.opacity = opacity / 100;
      return true;
   },
   setOpacity: function(num) {
      this.elem.style.opacity !== undefined ? this.elem.style.opacity = num / 100 : this.elem.style.filter = 'alpha(opacity = '+ num +')';
   },
    fadeIn: function(speed, opacity){
   /*
   speed ==>淡入的速度,正整数(可选);
   opacity ==>淡入到指定的透明度,0~100(可选);
      */
      speed = speed || 2;
      opacity = opacity || 100;
      let num = 0; // 初始化透明度变化值为0
      if (fadeFlag) {
        let time = setInterval(() => {
          num += speed;
          fadeFlag = false;
          this.setOpacity(num);
          this.elem.style.opacity !== undefined ? this.elem.style.opacity = num / 100 : this.elem.style.filter = 'alpha(opacity = '+ num +')';
          if (num >= opacity) {
            clearInterval(time);
            fadeFlag = true;
          }
        }, 20);
      }
    },
    fadeOut: function(speed, opacity) {
   /*
   speed ==>淡入的速度,正整数(可选);
   opacity ==>淡入到指定的透明度,0~100(可选);
   */
      speed = speed || 2;
      opacity = opacity || 0;
      let num = 100; // 初始化透明度变化值为0
      if (fadeFlag) {
        let time = setInterval(() => {
          num -= speed;
          fadeFlag = false;
          this.set(num);
          this.elem.style.opacity !== undefined ? this.elem.style.opacity = num / 100 : this.elem.style.filter = 'alpha(opacity = '+ num +')';
          if (num <= opacity) {
          clearInterval(time);
          fadeFlag = true;
          }
        }, 20);
      }
    }
  };
window.Fade = Fade;
})();
Copier après la connexion

Exemple de test :

let btn = document.getElementsByTagName(&#39;button&#39;)[0];
 let btn2 = document.getElementsByTagName(&#39;button&#39;)[1];
 btn.onclick = () => {
  let fade = new Fade('p1');
 fade.fadeIn();
 };
 btn2.onclick = () => {
  let fade = new Fade('p1');
  fade.fadeOut();
 }
Copier après la connexion

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. faites attention aux autres questions connexes dans l'article du site Web PHP chinois !

Lecture recommandée :

Traitement vue+storejs pour obtenir des données

Comment gérer le passage des paramètres dynamiques de requête dans vue- routeur

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