


Comment implémenter des effets de mise à l'échelle d'image et de loupe dans Vue ?
Comment implémenter la mise à l'échelle de l'image et l'effet de loupe dans Vue ?
Avec le développement continu de la technologie Web, les utilisateurs ont des exigences de plus en plus élevées en matière d'effet d'affichage des images sur le site Web. Parmi eux, le zoom d’image et les effets de loupe sont des exigences relativement courantes. Il est relativement simple d'implémenter des effets de mise à l'échelle d'image et de loupe dans Vue. Ensuite, je présenterai en détail la méthode d'implémentation spécifique.
1. Méthode de base
Tout d'abord, voyons comment obtenir l'effet de mise à l'échelle de base de l'image. La méthode d'implémentation est simple, il suffit d'utiliser les instructions intégrées de Vue v-bind et les styles de transformation.
Code HTML :
<template> <div> <div class="image-container"> <img class="image" :src="imageUrl" :style="`transform: scale(${scale})`" @mouseenter="onEnter" @mouseleave="onLeave" @mousemove="onMove" /> </div> </div> </template>
Dans le code ci-dessus, nous définissons un élément img et définissons un nom de classe pour son image. Le style de transformation de l'élément est calculé pour représenter sa mise à l'échelle.
Ensuite, nous devons attribuer et transmettre les variables qui doivent être utilisées dans le composant via les méthodes get et set dans l'attribut calculé.
Code JavaScript :
<script> export default { name: 'Image', data() { return { imageUrl: '/path/to/image', scale: 1 } }, computed: { onEnter() { this.scale = 2 }, onLeave() { this.scale = 1 }, onMove(e) { let scale = 2 let rect = e.target.getBoundingClientRect() let x = e.clientX - rect.left let y = e.clientY - rect.top let translateX = (scale - 1) * (-x) let translateY = (scale - 1) * (-y) let transformStyle = `transform: scale(${scale}); transform-origin: ${x}px ${y}px; translate(${translateX}px, ${translateY}px)` this.scale = transformStyle } } } </script>
En définissant trois propriétés calculées onEnter, onLeave et onMove et en les appelant dans les événements correspondants, nous pouvons facilement obtenir l'effet de mise à l'échelle de base de l'image.
2. Méthode avancée
Ensuite, voyons comment obtenir l'effet de loupe d'image. Cet effet permet à l'utilisateur d'agrandir la partie zoomée à travers un petit carré lors du zoom. Les méthodes d'implémentation sont fondamentalement les mêmes et il vous suffit d'apporter certaines modifications aux parties pertinentes du code.
Code HTML :
<template> <div> <div class="image-container" :style="`width: ${width}px; height: ${height}px`" @mouseenter="onEnter" @mouseleave="onLeave" @mousemove="onMove" > <img class="image" :src="imageUrl" :style="`transform: scale(${scale})`" ref="image" /> </div> <div class="magnifier-container" v-if="showMagnifier" :style="`transform: translate(-50%, -50%) scale(${scale}); top: ${mTop}px; left: ${mLeft}px`" > <div class="magnifier" :style="`background-image: url(${imageUrl}); background-size: ${width}px ${height}px; width: ${mWidth}px; height: ${mHeight}px;`" ></div> </div> </div> </template>
Dans ce composant, nous créons d'abord un élément div et définissons un nom de classe pour son conteneur d'images. Cet élément est utilisé pour contenir l'élément img et définir sa largeur et sa hauteur. Dans le même temps, nous avons remplacé les événements d'entrée, de sortie et de déplacement de la souris et les avons appelés dans les propriétés calculées.
Dans l'élément img, nous avons ajouté un attribut ref pour obtenir le handle de l'élément et l'utiliser dans l'attribut calculé.
Au bas du composant, nous créons un autre élément div pour contenir un petit carré. Cet élément obtient l'effet loupe en calculant l'attribut de style.
Ensuite, nous devons attribuer et transférer les définitions de variables et les méthodes de calcul pertinentes.
Code JavaScript :
<script> export default { name: 'Image', data() { return { imageUrl: '/path/to/image', width: 500, height: 350, scale: 1, showMagnifier: false, mWidth: 100, mHeight: 100, mTop: 0, mLeft: 0 } }, computed: { onEnter() { this.showMagnifier = true }, onLeave() { this.showMagnifier = false }, onMove(e) { let rect = this.$refs.image.getBoundingClientRect() let x = e.clientX - rect.left let y = e.clientY - rect.top this.mTop = y - this.mHeight / 2 this.mLeft = x - this.mWidth / 2 let translateX = (this.scale - 1) * (-x) let translateY = (this.scale - 1) * (-y) let transformStyle = `transform: scale(${this.scale}); transform-origin: ${x}px ${y}px; translate(${translateX}px, ${translateY}px)` this.scale = transformStyle } } } </script>
Dans le code ci-dessus, nous définissons les propriétés calculées onEnter, onLeave, onMove et les appelons dans les événements correspondants. Dans le même temps, nous avons également défini certaines variables auxiliaires et obtenu l'effet loupe en calculant et en attribuant des valeurs à ces variables.
3. Résumé
En implémentant des effets de zoom et de loupe sur l'image, l'effet d'affichage de l'image du site Web peut être rendu plus vivant et plus riche, améliorant ainsi l'expérience utilisateur. L'implémentation de cette fonction dans Vue est relativement simple et ne nécessite que certains calculs et applications pour la mener à bien.
Pendant le processus de mise en œuvre, nous pouvons effectuer des ajustements personnalisés en fonction de nos propres besoins et développer d'autres styles ou instructions d'événement. C’est peut-être aussi l’essence du développement continu de la technologie Web.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

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.

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.

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.

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.

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.

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.

La pagination est une technologie qui divise de grands ensembles de données en petites pages pour améliorer les performances et l'expérience utilisateur. Dans Vue, vous pouvez utiliser la méthode intégrée suivante pour la pagination: Calculez le nombre total de pages: TotalPages () Numéro de page de traversée: Directive V-FOR pour définir la page actuelle: CurrentPage Obtenez les données de la page actuelle: CurrentPagedata ()

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.
