美文网首页Web前端之路让前端飞
京东首页的响应式布局的实现原理

京东首页的响应式布局的实现原理

作者: 被时光移动的城 | 来源:发表于2017-06-08 11:09 被阅读509次

随着科技日新月异的发展,屏幕分辨率越来越高,4k屏的普及,1366屏已经很少见了,而1024屏更是几乎无人在使用了。现如今响应式的处理已经越来越少了,这对开发者来说是个好消息。但在一些大型网站还是做了响应式的处理,我们以京东首页为例,来看看是如何实现的吧:
效果图:
浏览器宽度较大时的效果:

浏览器宽度较大时的效果图.png

浏览器宽度较小时的效果:

浏览器宽度较小时的效果图.png

对比发现仅仅是整体宽度及中间的div的宽度改变,而其它没有改变。整体改变的宽度恰好等于中间div改变的宽度。
代码:
浏览器宽度较大时——jdbig.css

            *{
                margin: 0;
                padding: 0;
            }
            body{
                background: ghostwhite;
            }
            .user{
                width: 100%;
                height: 30px;
                background: #F1F1F1;
            }
            .user #user{
                width: 1210px;
                height: 30px;
                background: #A3A3A3;
                margin: 0 auto;
            }
            .top{
                width: 100%;
                height: 80px;
                background: #F04848;
            }
            .top img{
                display: block;
                margin: 0 auto;
            }
            .search{
                width: 100%;
                height: 150px;
                background: #FFFFFF;
            }
            #center{
                width: 100%;
                height: 454px;
                background: #F04848;
            }
            #center #flash{
                margin: 0 auto;
                width: 1210px;
                height: 454px;
                margin-bottom: 500px;
                position: relative;
            }
            #center #flash #left{
                float: left;
                width: 235px;
                height: 454px;
                background: white;
            }
            #center #flash #gg{
                width: 740px;
                height: 454px;
                float: left;
                background: #05FFE9;
            }
            #center #flash #right{
                float: right;
                width: 235px;
                height: 454px;
                background: white;
            }

浏览器宽度较小时——jdsmall.css

            *{
                margin: 0;
                padding: 0;
            }
            body{
                background: ghostwhite;
            }
            .user{
                width: 100%;
                height: 30px;
                background: #F1F1F1;
            }
            .user #user{
                width: 1010px;
                height: 30px;
                background: #A3A3A3;
                margin: 0 auto;
            }
            .top{
                width: 100%;
                height: 80px;
                background: #F04848;
            }
            .top img{
                display: block;
                margin: 0 auto;
            }
            .search{
                width: 100%;
                height: 150px;
                background: #FFFFFF;
            }
            #center{
                width: 100%;
                height: 454px;
                background: #F04848;
            }
            #center #flash{
                margin: 0 auto;
                width: 1010px;
                height: 454px;
                margin-bottom: 500px;
                position: relative;
            }
            #center #flash #left{
                float: left;
                width: 235px;
                height: 454px;
                background: white;
            }
            #center #flash #gg{
                width: 540px;
                height: 454px;
                float: left;
                background: #05FFE9;
            }
            #center #flash #right{
                float: right;
                width: 235px;
                height: 454px;
                background: white;
            }

页面布局:

            <!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <link rel="stylesheet" type="text/css" href="css/jdbig.css" media="screen and (min-width:1210px)" />
        <link rel="stylesheet" type="text/css" href="css/jdsmall.css" media="screen and (max-width:1210px)" />
    </head>
    <body>
        <div class = "user">
            <div id="user">
            </div>
        </div>
        <div class = "top">
            ![](../img/top.jpg)
        </div>
        <div class="search"></div>
        <div id="center">
        <div id="flash">
            <div id="left"></div>
            <div id="gg"></div>
            <div id="right"></div>
        </div>
        </div>
    </body>
</html>

如有问题欢迎交流。

如转载请注明出处,谢谢!

相关文章

  • 京东首页的响应式布局的实现原理

    随着科技日新月异的发展,屏幕分辨率越来越高,4k屏的普及,1366屏已经很少见了,而1024屏更是几乎无人在使用了...

  • VUE响应式原理

    VUE响应式原理 这里的响应式(Reactive)不同于CSS布局的响应式(Responsive), 这里的响应式...

  • 响应式布局---bootstrap框架

    移动端WEB开发之响应式布局 1.0 响应式开发原理 1.1 响应式开发原理 就是使用媒体查询针对不同宽度的设备进...

  • 响应式网页设计、响应式布局的实现原理

    概念响应式网页设计最初是由 Ethan Marcotte 提出的一个概念:为什么一定要为每个用户群各自打造一套设计...

  • Vue3.0 常用响应式API的使用和原理分析(一)

    前面关于响应式的两篇文章,分别介绍了响应式实现原理和计算属性,本篇文章我们来看看其他响应式API的使用和实现原理。...

  • grid实现响应式布局

    一行 CSS 代码实现响应式布局 – 使用 Grid 实现的响应式布局 在这篇文章中,我将教你如何使用 CSS G...

  • 移动 web 开发 —— 响应式布局

    1.0 响应式开发原理 1.1 响应式开发原理 就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不...

  • 移动端WEB开发之响应式布局

    1.0 响应式开发原理 1.1 响应式开发原理 就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不...

  • 移动端开发之响应式布局

    1.0 响应式开发原理 1.1 响应式开发原理 就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不...

  • 双向绑定

    数据响应式原理 vue实现数据响应式的原理就是利用了Object.defineProperty(),重新定义了对象...

网友评论

    本文标题:京东首页的响应式布局的实现原理

    本文链接:https://www.haomeiwen.com/subject/ejvzfxtx.html