Maison interface Web tutoriel HTML 图片放大镜注释详解_html/css_WEB-ITnose

图片放大镜注释详解_html/css_WEB-ITnose

Jun 24, 2016 am 11:15 AM

今天的练习是做一个网购网站常见的图片详情介绍的放大镜效果,简单来说就是图片中有对应的区域让你看到放大后的效果。

关于布局:就是两组div,第一组大div放图片,小的是遮盖层。第二组是大图div显示框,里面放大张图片,超过部分隐藏,可以想象下是透过窗户看外面,你看到的只是一部分。

思路:就是两边的比例,重点,比例,话不说,直接上代码。

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>        <style>            *{margin:0 ; padding:0;}            #left{width:300px;                    height:300px;                    border:1px solid gold;                    position:relative;                    float:left;                    margin-right:20px;                    left:10px;                    top:10px;}            #left img{width:300px;                        height:300px;}            #mask{width:90px;                    height:90px;                    background:greenyellow;                    opacity: 0.5;                    position: absolute;                    top:0;                    left:0;                    display:none;                    cursor: move;}            #big{width:600px;                    height:600px;                    overflow: hidden;                    float: left;                    position:relative;                    left: 10px;                    top:10px;                    display:none;                    border:1px solid goldenrod;}            #big img{position: absolute;                    left:0;                    top:0;}                    </style>    </head>    <body>        <div id="left">            <img  src="/static/imghw/default1.png"  data-src="img/5-140526101943.jpg"  class="lazy" / alt="图片放大镜注释详解_html/css_WEB-ITnose" >            <div id="mask"></div>        </div>        <div id="big">            <img  src="/static/imghw/default1.png"  data-src="img/5-140526101943.jpg"  class="lazy" / alt="图片放大镜注释详解_html/css_WEB-ITnose" >        </div>        <script>                 // 左边遮罩层与左边显示框大小的比例对应大图显示区与图片的比例                     window.onload = function(){                var left = document.getElementById("left");                var mask = document.getElementById("mask");                var big = document.getElementById("big");                var bigImg = big.children[0];                                //鼠标移入,遮罩层显示,大图显示区显示                left.onmouseenter = function(){                    mask.style.display = big.style.display ='block';                };                //鼠标移出,遮罩层隐藏,大图显示区隐藏                left.onmouseleave = function(){                    mask.style.display= big.style.display = 'none';                };                                //鼠标移动,遮罩层跟随鼠标,大图显示相关内容                left.onmousemove = function(ev){                    //兼容IE                    var ev = ev || event;                       
Copier après la connexion

//鼠标在遮罩层中居中显示,鼠标的位置-显示区到body的距离-遮罩层的一半//后面是赋值给遮罩层的距离,所以用到减,鼠标位置不变,是遮罩层在变,所以需要用到减,遮罩层往回挪

                    var l = ev.clientX-this.offsetLeft-mask.offsetWidth/2;                    var t = ev.clientY-this.offsetTop-mask.offsetHeight/2;                    //不让遮罩层出左边显示框的范围                    if(l<=0){                        l=0                    }else if(l>=left.clientWidth - mask.offsetWidth){                        l = left.clientWidth - mask.offsetWidth                    }                    if(t<=0){                        t=0                    }else if(t>=left.clientHeight - mask.offsetHeight){                        t = left.clientHeight - mask.offsetHeight                    }                    //比例,将能够移动的距离做比例                    var percX = l/(this.clientWidth- mask.offsetWidth);                    var percY = t/(this.clientHeight- mask.offsetHeight);                    //大图显示区                                        bigImg.style.left = -percX*(bigImg.offsetWidth - big.clientWidth)+'px';                    bigImg.style.top = -percY*(bigImg.offsetHeight - big.clientHeight)+'px';                    //遮罩层的位置                    mask.style.left = l +'px';                    mask.style.top = t +'px';                };            };        </script>    </body></html>
Copier après la connexion

这是做完的效果,我不知怎么插入图片文件,建议您可以自己拿张图片,修改下地址就行,最好是等宽高的,还有一点就是,如果你觉着遮罩层和显示区域的图片差太多,那你就可以修改下遮罩层的大小就行了。

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

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

HTML est-il facile à apprendre pour les débutants? HTML est-il facile à apprendre pour les débutants? Apr 07, 2025 am 12:11 AM

HTML convient aux débutants car il est simple et facile à apprendre et peut rapidement voir les résultats. 1) La courbe d'apprentissage de HTML est fluide et facile à démarrer. 2) Il suffit de maîtriser les balises de base pour commencer à créer des pages Web. 3) Flexibilité élevée et peut être utilisée en combinaison avec CSS et JavaScript. 4) Les ressources d'apprentissage riches et les outils modernes soutiennent le processus d'apprentissage.

Les rôles de HTML, CSS et JavaScript: responsabilités de base Les rôles de HTML, CSS et JavaScript: responsabilités de base Apr 08, 2025 pm 07:05 PM

HTML définit la structure Web, CSS est responsable du style et de la mise en page, et JavaScript donne une interaction dynamique. Les trois exercent leurs fonctions dans le développement Web et construisent conjointement un site Web coloré.

Comprendre HTML, CSS et JavaScript: un guide pour débutant Comprendre HTML, CSS et JavaScript: un guide pour débutant Apr 12, 2025 am 12:02 AM

WebDevelopmentReliesOnHTML, CSS, etjavascript: 1) HTMLSTRUCTURESCONTENT, 2) CSSSTYLESIT, et3) JavascriptAdddsInterActivity, Forming TheasisofmodernweBEBExperiences.

Quel est un exemple d'une balise de départ dans HTML? Quel est un exemple d'une balise de départ dans HTML? Apr 06, 2025 am 12:04 AM

Anexampleofastartingtaginhtmlis, qui abinginsaparagraph.startingtagsaressentialtinhtmlastheyinitiateelements, définit les éventualités, et la faculté de réduction des pages et de la construction de la création.

Gitee Pages STATIQUE Le déploiement du site Web a échoué: comment dépanner et résoudre les erreurs de fichier unique 404? Gitee Pages STATIQUE Le déploiement du site Web a échoué: comment dépanner et résoudre les erreurs de fichier unique 404? Apr 04, 2025 pm 11:54 PM

GiteEpages STATIQUE Le déploiement du site Web a échoué: 404 Dépannage des erreurs et résolution lors de l'utilisation de Gitee ...

Comment implémenter la disposition adaptative de la position de l'axe y dans l'annotation Web? Comment implémenter la disposition adaptative de la position de l'axe y dans l'annotation Web? Apr 04, 2025 pm 11:30 PM

L'algorithme adaptatif de la position de l'axe y pour la fonction d'annotation Web Cet article explorera comment implémenter des fonctions d'annotation similaires aux documents de mots, en particulier comment gérer l'intervalle entre les annotations ...

HTML, CSS et JavaScript: outils essentiels pour les développeurs Web HTML, CSS et JavaScript: outils essentiels pour les développeurs Web Apr 09, 2025 am 12:12 AM

HTML, CSS et JavaScript sont les trois piliers du développement Web. 1. HTML définit la structure de la page Web et utilise des balises telles que, etc. 2. CSS contrôle le style de page Web, en utilisant des sélecteurs et des attributs tels que la couleur, la taille de la police, etc. 3. JavaScript réalise les effets dynamiques et l'interaction, par la surveillance des événements et les opérations DOM.

Comment utiliser CSS3 et JavaScript pour réaliser l'effet de la diffusion et de l'agrandissement des images environnantes après avoir cliqué? Comment utiliser CSS3 et JavaScript pour réaliser l'effet de la diffusion et de l'agrandissement des images environnantes après avoir cliqué? Apr 05, 2025 am 06:15 AM

Pour obtenir l'effet de la diffusion et de l'élargissement des images environnantes après avoir cliqué sur l'image, de nombreuses conceptions Web doivent obtenir un effet interactif: cliquez sur une certaine image pour faire les environs ...

See all articles