Maison  >  Article  >  interface Web  >  Une brève discussion sur javascript pour acquérir des compétences en matière de transformation d'éléments paramètres_javascript

Une brève discussion sur javascript pour acquérir des compétences en matière de transformation d'éléments paramètres_javascript

WBOY
WBOYoriginal
2016-05-16 15:49:171810parcourir

Quand j'écrivais une page auparavant, j'ai essayé d'utiliser js pour obtenir la valeur de traduction de certains éléments, mais traduire est un sous-style de transformation (j'en parle à peine, bien sûr, je devrais obtenir le). transformez d'abord le style, puis lisez la valeur intérieure.

Copier le code Le code est le suivant :

corps{-webkit-transform : translateX(20px);}

Mais quand j'ai essayé ça, un miracle s'est produit :

Mon cœur s'est presque effondré à ce moment-là. Je voulais juste comprendre tranquillement la valeur de la traduction. Qui aurait cru que cette chose allait apparaître pour moi ? Même si j'avais aussi parlé de tous les changements dans le cours de mathématiques avancées (bidimensionnel, les effets bidimensionnels, tridimensionnels) peuvent être concentrés dans une matrice, mais si je veux analyser la matrice de manière inverse pour obtenir la valeur souhaitée, ce n'est pas si simple.

Par hasard, j'ai encore une fois voulu utiliser js pour obtenir la valeur de traduire. Cette fois, le résultat était inattendu :

En voyant cette scène, j'ai fondu en larmes. Même si je ne peux pas obtenir directement la valeur que je veux, je peux simplement la faire correspondre avec l'expression régulière.

Pensez-vous que jq a fait quelque chose ? En fait, ce n’est pas le cas. J’ai comparé et j’ai constaté que les deux styles de carrosserie s’écrivent différemment :

Première fois :

Copier le code Le code est le suivant :
body{-webkit-transform : translateX(20px); }

Deuxième fois :

Copier le code Le code est le suivant :

Oui, la première fois est définie via CSS, et la deuxième fois est définie via l'attribut style du corps. D'après ma compréhension, bien que les attributs CSS et style puissent restituer les éléments de la page, leur statut n'est pas le même. (Ce qui suit contient des ingrédients spéculés)

Lorsque la page est chargée, le CSS et le style ont un effet sur l'arbre de rendu, et ils affecteront la réalisation de l'élément. La différence est que le style est un attribut de l'élément. Quel que soit le paramètre défini par l'utilisateur, il devrait l'être. enregistré, et cela laissera une empreinte profonde dessus sur un élément spécifique, donc lorsque le corps définit '-webkit-transform' via le style, nous pouvons obtenir la valeur définie telle quelle via document.body.style.webkitTransform. Peut-être avez-vous des questions, ne serait-il pas préférable d'obtenir directement la valeur du paramètre CSS ? Mais je pense que c'est impossible (sauf pour la méthode d'analyse du fichier CSS), car le fichier CSS est chargé et sa tâche est terminée une fois l'arborescence de rendu formée. Les règles finales pour le rendu des éléments générés par CSS et le style sont toutes Can. être trouvé via window.getComputedStyle(element). Grâce à cette méthode, nous pouvons voir que les règles de rendu finalement générées par transform sont enregistrées sous forme de matrice maxrix(x,x,x,x,x) (peut-être pour faciliter les opérations informatiques),

Cela explique pourquoi $('body').css('-webkit-transform') renvoie une matrice, et cela montre également que la méthode $().css() est finalement rendue à partir du navigateur. Le résultat est renvoyé dans la règle (window.getComputedStyle(element)), il ne peut donc pas lire vos paramètres de configuration CSS, et lorsque vous utilisez $().css() pour définir les styles des éléments, il définit en fait l'attribut de style d'élément (en ligne) est ensemble, essayez-le et vous saurez. Bien que ce $().css() contienne le mot « css », cela n'a rien à voir avec le « fichier css ». Peut-être que cela peut prouver ce que j'ai dit ci-dessus : « la valeur définie par css ne peut pas être obtenue directement ».

Résumé :

1.css et style fonctionnent ensemble sur l'arbre de rendu, et la valeur définie par style sera enregistrée en tant que sous-propriété de l'attribut de style de l'élément. La règle de rendu finale peut être trouvée via window.getComputedStyle(element)<.>

La méthode 2.jq$().css() obtient les règles de rendu finales et définit l'attribut de style (style en ligne)

Recommandation :

1. Lorsque nous devons obtenir et modifier les paramètres de transformation de l'élément en temps réel (par exemple en utilisant la traduction pour obtenir divers effets de glissement), nous devons définir la transformation sur l'attribut en ligne de l'élément (défini via le style) , pour qu'il soit facile à lire

2. Même si la matrice fait peur, si vous ne voulez pas devenir un pageur ordinaire, encore faut-il la comprendre

Ce qui précède représente l’intégralité du contenu de cet article, j’espère que vous l’aimerez tous.

Déclaration:
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