本文实例为大家分享了JS实现京东放大镜效果的具体代码,供大家参考,具体内容如下

需要实现的效果图如下:

①布局:布局采用一个大盒子里面首先分为上下两个部分,然后下部分又分为左右两个部分。左边的盒子里面放了一个img和一个遮罩层cover,右边盒子里面放的是800*800的大图片,这里提供左边的图片b3.png和右边的大图片big.jpg:

注意:左边盒子里面的cover采用绝对定位,右边盒子里面的img采用绝对定位。

②功能实现:主要有三个功能模块:

1.鼠标经过(mouseover)左边盒子,黄色的遮罩层以及右边盒子显示,鼠标离开(mouseout)则隐藏黄色遮罩层以及右边盒子。

2.黄色遮罩层跟随鼠标移动(mousemove)。鼠标在盒子的坐标=鼠标在页面的坐标-左边盒子在页面的坐标,但是又因为鼠标是在遮罩层的中间,所以最终的坐标要减去遮罩层一半的高度和宽度。注意这里有边界条件:就是黄色遮罩层的移动距离,黄色遮罩层的x方向的移动距离不能小于0且不能大于左边盒子宽度减去遮罩层的宽度。

3.移动黄色遮罩层,大图片跟随移动功能。大图片移动的距离根据下面这个公式来进行计算:

遮挡层的移动距离上一点已经算过了,遮罩层的最大移动距离上面也说了,剩下的就是大图片最大移动距离,大图片最大移动距离=图片的大小-右边盒子的大小。

最后全部代码如下:

html代码:

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>京东放大镜效果</title>
    <script src="../js/index.js"></script>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        
        ul li {
            list-style: none;
        }
        /* 外面大盒子 */
        
        .container {
            box-sizing: border-box;
            width: 1200px;
            height: 500px;
            /* background-color: pink; */
            margin: 200px auto;
        }
        
        .container .topbox {
            width: 100%;
            height: 60px;
            /* background-color: violet; */
            border-bottom: 2px solid #bc2815;
        }
        
        .container .topbox ul {
            margin-left: 10px;
        }
        
        .container .topbox ul li {
            float: left;
            font-size: 22px;
            color: #4e535b;
            padding: 15px 20px;
        }
        
        .container .topbox ul li:hover {
            color: white;
            background-color: #bc2815;
        }
        
        .container .topbox ul li:first-child {
            color: white;
            background-color: #bc2815;
        }
        
        .container .bottombox .leftbox {
            float: left;
            height: 400px;
            width: 400px;
            /* background-color: violet; */
            margin-top: 10px;
        }
        
        .container .bottombox .leftbox ul {
            overflow: hidden;
            margin-left: 10px;
        }
        
        .container .bottombox .leftbox ul li {
            float: left;
            font-size: 14px;
            color: #4e535b;
        }
        
        .container .bottombox .leftbox .leftphone {
            position: relative;
            overflow: hidden;
            width: 400px;
            height: 400px;
            /* background-color: pink; */
            margin-top: 5px;
            margin-left: 10px;
            border: 1px solid #c8cbc8;
        }
        
        .leftbox .leftphone img {
            width: 100%;
            height: 100%;
        }
        
        .container .bottombox .leftbox .leftphone .cover {
            position: absolute;
            display: none;
            top: 0;
            left: 0;
            width: 220px;
            height: 220px;
            background-color: #ffeba2;
            opacity: 0.5;
            border: 1px solid #ccc;
            cursor: move;
        }
        
        .container .bottombox .rightbox {
            float: left;
            margin-top: 10px;
            width: 420px;
            height: 420px;
            margin-left: 20px;
            /* background-color: violet; */
        }
        
        .container .bottombox .rightbox {
            position: relative;
            display: none;
            border: 1px solid #ccc;
            overflow: hidden;
        }
        
        .container .bottombox .rightbox img {
            position: absolute;
            top: 0;
            left: 0;
        }
    </style>
</head>
 
<body>
    <div class="container">
        <div class="topbox">
            <ul>
                <li>全部商品分类</li>
                <li>服装城</li>
                <li>美妆馆</li>
                <li>传智超市</li>
                <li>全球购</li>
                <li>闪购</li>
                <li>团购</li>
                <li>拍卖</li>
                <li>有趣</li>
            </ul>
        </div>
        <div class="bottombox">
            <div class="leftbox">
                <div class="leftnav">
                    <ul>
                        <li>手机、数码、通讯&nbsp;&nbsp;></li>
                        <li>手机&nbsp;&nbsp;></li>
                        <li>Apple苹果&nbsp;&nbsp;></li>
                        <li>iphone 6S Plus系统&nbsp;&nbsp;</li>
                    </ul>
                    <div class="leftphone">
                        <img src="../b3.png" alt="">
                        <div class="cover"></div>
                    </div>
                </div>
            </div>
            <div class="rightbox">
                <img src="../big.jpg" alt="" class="big">
            </div>
        </div>
 
    </div>
</body>
 
</html>

外部js文件:

window.addEventListener('load', function() {
    // 获取元素
    var cover = this.document.querySelector('.cover');
    var leftphone = this.document.querySelector('.leftphone');
    var rightbox = this.document.querySelector('.rightbox');
    var big = this.document.querySelector('.big');
    // 鼠标移动到左边的手机上的时候遮罩层和右边的手机显示出来
    leftphone.addEventListener('mouseover', function() {
        cover.style.display = 'block'
        rightbox.style.display = 'block'
    })
    // 鼠标移离开到左边的手机上的时候遮罩层和右边的手机隐藏 
    leftphone.addEventListener('mouseout', function() {
        cover.style.display = 'none'
        rightbox.style.display = 'none'
    })
    leftphone.addEventListener('mousemove', function(e) {
        var x = e.pageX - this.offsetLeft;
        var y = e.pageY - this.offsetTop;
        // x的移动距离
        var totalx = x - cover.offsetWidth / 2;
        var totaly = y - cover.offsetHeight / 2
        if (totalx < 0) {
            totalx = 0;
        } else if (totalx >= leftphone.offsetWidth - cover.offsetWidth) {
            totalx = leftphone.offsetWidth - cover.offsetWidth;
        }
        if (totaly < 0) {
            totaly = 0;
        } else if (totaly >= leftphone.offsetHeight - cover.offsetHeight) {
            totaly = leftphone.offsetHeight - cover.offsetHeight;
        }
        cover.style.left = totalx   'px';
        cover.style.top = totaly   'px';
        // imgmaxx是图片最大x移动距离
        var imgmaxx = rightbox.offsetWidth - big.offsetWidth;
        var imgmaxy = rightbox.offsetHeight - big.offsetHeight;
        var imgmovex = totalx * imgmaxx / (leftphone.offsetWidth - cover.offsetWidth)
        var imgmovey = totaly * imgmaxy / (leftphone.offsetHeight - cover.offsetHeight)
        big.style.left = imgmovex   'px';
        big.style.top = imgmovey   'px';
 
    })
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持Devmax。

JS实现京东放大镜效果的更多相关文章

  1. html5 拖拽及用 js 实现拖拽功能的示例代码

    这篇文章主要介绍了html5 拖拽及用 js 实现拖拽,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. amaze ui 的使用详细教程

    这篇文章主要介绍了amaze ui 的使用详细教程,本文通过多种方法给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. swift皮筋弹动发射飞机ios源码

    这是一个款采用swift实现的皮筋弹动发射飞机游戏源码,游戏源码比较详细,大家可以研究学习一下吧。

  4. Swift与Js通过WebView交互

    开发环境:Swfit2.3XCode8.2基础概念jscontext,jscontext是代表JS的执行环境,通过-evaluateScript:方法就可以执行一JS代码JSValue,JSValue封装了JS与ObjC中的对应的类型,以及调用JS的API等JSExport,JSExport是一个协议,遵守此协议,就可以定义我们自己的协议,在协议中声明的API都会在JS中暴露出来,才能调用Swif

  5. JSCore swift

    如果双方相互引用,会造成循环引用,而导致内存泄露。以上是Jscore的基本使用,比较简单

  6. Swift WKWebView的js调用swift

    最近项目需求,需要用到JavaScriptCore和WebKit,但是网上的资源有限,而且比较杂,都是一个博客复制另外一个博客,都没有去实际敲代码验证,下面给大家分享一下我的学习过程。

  7. Swift WKWebView的swift调用js

    不多说,直接上代码:在html里面要添加的的代码,显示swift传过去的参数:这样就实现了swift给js传参数和调用!

  8. 在 Swift 專案中使用 Javascript:編寫一個將 Markdown 轉為 HTML 的編輯器

    你有強烈的好奇心,希望在你的iOS專案中使用JavaScript。jscontext中的所有值都是JSValue對象,JSValue類用於表示任意類型的JavaScript值。因此,我們既需要寫Swift代碼也要寫JavaScript代碼。此外,我們還會在JavaScript中按照這個類的定義來創建一個對象并對其屬性進行賦值。從Swift中呼叫JavaScript就如介紹中所言,JavaScriptCore中最主要的角色就是jscontext類。一個jscontext對象是位於JavaScript環境和本

  9. swift - WKWebView JS 交互

    本文介绍WKWebView怎么与js交互,至于怎么用WKWebView这里就不介绍了HTML代码APP调JS代码结果JS给APP传参数首先注册你需要监听的js方法名2.继承WKScriptMessageHandler并重写userContentController方法,在该方法里接收JS传来的参数3.结果

  10. swift 开发UIWebView跟JS的交互

    前言作为小白的我,才开始入门IOS,选择了swift来进行入门学习,学习做着公司一个简单的小小项目,该项目需要进行跟H5进行交互,然后我就开始研究了UIWebView的使用,其实基本原理跟Android的一样,因为我是Android开发的,所以就顺水推舟了。))//这里设置你需要加载的地址}overridefuncdidReceiveMemoryWarning(){super.didReceiveMemoryWarning()//disposeofanyresourcesthatcanberecreate

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部