HTML中移动端有哪些布局方案

最近我研究了淘宝,天猫和网易彩票163的wap主页样式布局,今天给大家来总结一些移动端布局方案,并且分析一下所使用技术的利弊。

注意:代码运行是file协议,在chrome里不支持引用本地文件,会提示跨域错误,可以用firefox或者Safari打开

wty2368

移动端布局方案探究

研究了淘宝,天猫和网易彩票163的wap主页样式布局,总结移动端布局方案
注意:代码运行是file协议,在chrome里不支持引用本地文件,会提示跨域错误,可以用firefox或者Safari打开

立即学习“前端免费学习笔记(深入)”;

当时做的ppt下载: 2015年12月移动端布局方案探究

一、基本概念

1. 物理像素(physical pixel)

一个物理像素是显示器(手机屏幕)上最小的物理显示单元

2. 设备独立像素(density-independent pixel)

设备独立像素(也叫密度无关像素),可以认为是计算机坐标系统中得一个点,这个点代表一个可以由程序使用的虚拟像素(比如: CSS像素)

3. 位图像素

一个位图像素是栅格图像(如:png, jpg, gif等)最小的数据单元。每一个位图像素都包含着一些自身的显示信息(如:显示位置,颜色值,透明度等)

4. 设备像素比(简称dpr)

设备像素比 = 物理像素 / 设备独立像素(在某一方向上,x方向或者y方向)

5. scale

缩放比:

scale = 1/dpr

6. 完美视口


二、网易彩票设计方案

网易彩票

采用scale = 1.0写死viewport

采用媒体查询来确定html根元素的font-size值,即rem值

rem + 百分比布局

媒体查询的css代码如下:

//网易彩票的响应式布局是采用媒体查询来改变rem值实现的//媒体查询css#media-query{    @media screen and (min-width: 240px) {        html,body,button,input,select,textarea {            font-size:9px!important;        }    }    @media screen and (min-width: 320px) {        html,body,button,input,select,textarea {            font-size:12px!important;        }    }    @media screen and (min-width: 374px) {        html,body,button,input,select,textarea {            font-size:14px!important;        }    }    @media screen and (min-width: 400px) {        html,body,button,input,select,textarea {            font-size:15px!important;        }    }    // 省略}

三、天猫设计方案

天猫首页

采用scale = 1.0写死viewport

不采用rem,body的font-size=14px写死

px + flexbox布局

四、遇到的问题

1. 高清屏下( dpr>1 )1px线模糊问题

大多数情况下,设计师产出各种尺寸的稿子,都是先画出大尺寸(一般2x)的稿子,再去缩小尺寸,最后导出。 这样会带来问题:如果设计师在2倍稿子里画了一条1px的线(例如border:1px),这时候假如我们要在scale=1.0里呈现的话,就会变成0.5px,而很大一部分手机是无法画出0.5px的。
理论上,1个位图像素对应于1个物理像素,图片才能得到完美清晰的展示。在普通屏幕下是没有问题的,但是在retina屏幕(dpr=2)下就会出现位图像素点不够,从而导致图片模糊的情况。

2. 高清屏下( dpr>1 )高清图片模糊问题

对于dpr=2的retina屏幕而言,1个位图像素对应于4个物理像素,由于单个位图像素不可以再进一步分割,所以只能就近取色,从而导致图片模糊(注意上述的几个颜色值)。所以,对于图片高清问题,比较好的方案就是采用两倍图片。如:200×300(css pixel)img标签,就需要提供400×600的图片。
对于dpr=2的retina屏幕而言,1个位图像素对应于4个物理像素,由于单个位图像素不可以再进一步分割,所以只能就近取色,从而导致图片模糊(注意上述的几个颜色值)。所以,对于图片高清问题,比较好的方案就是采用两倍图片。如:200×300(css pixel)img标签,就需要提供400×600的图片。

五、终极解决方案–>淘宝设计方案

淘宝首页

通过js处理获取手机dpr参数,然后动态生成viewpoint

获取手机物理像素宽度,分成10份,每一份的宽度即是rem的尺寸。

根据设计稿的尺寸(px)分三种情况进行处理,采用px + rem布局

相关的脚本如下:

$(document).ready(function(){    var dpr, rem, scale;    var docEl = document.documentElement;    var fontEl = document.createElement('style');    var metaEl = document.querySelector('meta[name="viewport"]');    var view1 = document.querySelector('#view-1');    if(window.screen.width < 540){        dpr = window.devicePixelRatio || 1;        scale = 1 / dpr;        rem = docEl.clientWidth * dpr / 10;    }else{        dpr = 1;        scale =1;        rem = 54;    }//貌似最新的淘宝网站又去掉了,只是限制了主体内容的宽度    // 设置viewport,进行缩放,达到高清效果    metaEl.setAttribute('content', 'width=' + dpr * docEl.clientWidth + ',initial-scale=' + scale + ',maximum-scale=' + scale + ', minimum-scale=' + scale + ',user-scalable=no');    // 设置整体div的宽高    view1.setAttribute('style', 'width:'+ docEl.clientWidth+'px; height:'+ docEl.clientHeight+'px');    // 设置data-dpr属性,留作的css hack之用    docEl.setAttribute('data-dpr', dpr);    // 动态写入样式    docEl.firstElementChild.appendChild(fontEl);    fontEl.innerHTML = 'html{font-size:' + rem + 'px!important;}';    $('body').attr('style', 'font-size:' + dpr * 12 +'px');    // 给js调用的,某一dpr下rem和px之间的转换函数    window.rem2px = function(v) {        v = parseFloat(v);        return v * rem;    };    window.px2rem = function(v) {        v = parseFloat(v);        return v / rem;    };    window.dpr = dpr;    window.rem = rem;})

六、设计方案总结

从以上的分析我们不难看出:

网易彩票的方案上手快,开发效率高,兼容性好,但是不够灵活和精细;

天猫的设计思路比较简单,flexbox非常灵活,但是flexbox的兼容性方面需要好好处理,不够精细;

淘宝的方案几乎解决了移动端遇到的所有问题,堪称完美的解决方案,但是开发效率低、成本比较高。

相信看了这些案例你已经掌握了方法,更多精彩请关注创想鸟其它相关文章!

相关阅读:

HTML中的滚动条有哪些使用技巧

html两秒跳转至其他页面

怎样使用trigger方式实现不用点击file类型的input弹出文件选择对话框

a标签中怎样设置隐藏其他属性只显示图片

以上就是HTML中移动端有哪些布局方案的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1545814.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 17:29:32
下一篇 2025年12月21日 17:29:43

相关推荐

  • CSS中contain的语法使用场景

    CSS中contain的语法使用场景 在CSS中,contain是一个有用的属性,用于指定元素的内容是否独立于其外部样式和布局。它可以帮助开发者更好地控制页面布局和优化性能。本文将介绍contain属性的语法使用场景,并提供具体的代码示例。 contain属性的语法如下: contain: layo…

    2025年12月24日
    000
  • CSS中float布局介绍

    CSS中的float布局介绍 在网页开发中,我们经常会用到CSS来控制页面的样式和布局。其中,float布局是一种常用的布局方式。它可以实现元素的浮动效果,使得多个元素并排显示。本文将介绍float布局的用法和常见应用,并提供具体的代码示例。 一、float布局的用法 使用float属性 在CSS中…

    2025年12月24日
    000
  • 学会从头开始学习CSS,掌握制作基本网页框架的技巧

    从零开始学习CSS,掌握网页基本框架制作技巧 前言: 在现今互联网时代,网页设计和开发是一个非常重要的技能。而学习CSS(层叠样式表)是掌握网页设计的关键之一。CSS不仅可以为网页添加样式和布局,还可以为用户呈现独特且具有吸引力的页面效果。在本文中,我将为您介绍一些基本的CSS知识,以及一些常用的代…

    2025年12月24日
    200
  • 揭秘Web标准涵盖的语言:了解网页开发必备的语言范围

    在当今数字时代,互联网成为了人们生活中不可或缺的一部分。作为互联网的基本构成单位,网页承载着我们获取和分享信息的重要任务。而网页开发作为一门独特的技术,离不开一些必备的语言。本文将揭秘Web标准涵盖的语言,让我们一起了解网页开发所需的语言范围。 首先,HTML(HyperText Markup La…

    2025年12月24日
    000
  • 网页布局中的元素选择器的应用

    元素选择器在网页布局中的应用,需要具体代码示例 随着互联网的不断发展,网页设计和布局变得越来越重要。为了实现网页的美观和功能,我们需要使用 CSS (层叠样式表)来定义网页的外观和样式。而元素选择器是 CSS 中最常用和基本的选择器之一,它能够帮助我们对页面上的元素进行精确的定位和样式设置。 一、元…

    2025年12月24日
    000
  • 揭开Web开发的语言之谜:了解构建网页所需的语言有哪些?

    Web标准中的语言大揭秘:掌握网页开发所需的语言有哪些? 随着互联网的快速发展,网页开发已经成为人们重要的职业之一。而要成为一名优秀的网页开发者,掌握网页开发所需的语言是必不可少的。本文将为大家揭示Web标准中的语言大揭秘,介绍网页开发所需的主要语言。 HTML(超文本标记语言)HTML是网页开发的…

    2025年12月24日
    400
  • 常用的网页开发语言:了解Web标准的要点

    了解Web标准的语言要点:常见的哪些语言应用在网页开发中? 随着互联网的不断发展,网页已经成为人们获取信息和交流的重要途径。而要实现一个高质量、易用的网页,离不开一种被广泛接受的Web标准。Web标准的制定和应用,涉及到多种语言和技术,本文将介绍常见的几种语言在网页开发中的应用。 首先,HTML(H…

    2025年12月24日
    000
  • 网页开发中常见的Web标准语言有哪些?

    探索Web标准语言的世界:网页开发中常用的语言有哪些? 在现代社会中,互联网的普及程度越来越高,网页已成为人们获取资讯、娱乐、交流的重要途径。而网页的开发离不开各种编程语言的应用和支持。在这个虚拟世界的网络,有许多被广泛应用的标准化语言,用于为用户提供优质的网页体验。本文将探索网页开发中常用的语言,…

    2025年12月24日
    000
  • 深入探究Web标准语言的范围,涵盖了哪些语言?

    Web标准是指互联网上的各个网页所需遵循的一系列规范,确保网页在不同的浏览器和设备上能够正确地显示和运行。这些标准包括HTML、CSS和JavaScript等语言。本文将深入解析Web标准涵盖的语言范围。 首先,HTML(HyperText Markup Language)是构建网页的基础语言。它使…

    2025年12月24日
    000
  • 使用正确的CSS布局单位,创造精美的网页设计

    选择合适的CSS布局单位,打造优雅的网页设计 在网页设计中,CSS布局单位是至关重要的一部分。不同的布局单位可以帮助我们更好地控制网页元素的大小、间距和位置,从而打造出优雅、美观的网页设计。本文将介绍几种常见的CSS布局单位,并提供具体的代码示例。 像素(px)单位 像素是最常见的CSS布局单位之一…

    2025年12月24日
    000
  • 使用CSS实现响应式图片卡片布局的技巧

    使用CSS实现响应式图片卡片布局的技巧 随着移动设备的普及和网络速度的提升,人们在浏览网页时越来越重视页面的响应式布局。作为页面设计的关键元素之一,图片在响应式布局中扮演着重要角色。本文将介绍一种使用CSS实现响应式图片卡片布局的技巧,帮助你在不同设备上展示美观且兼容的图片卡片。 实现响应式图片卡片…

    2025年12月24日
    000
  • CSS Flexbox布局:利用弹性盒子布局实现灵活的布局结构

    CSS Flexbox布局:灵活的布局结构实现 简介:在前端开发中,页面布局是一个重要的环节。传统的布局方式,如使用浮动或定位,有时候在设计不符合标准化的情况下会出现一系列问题。为了克服这些问题,CSS3引入了Flexbox布局,它可以为开发者提供更灵活和强大的页面布局解决方案。 Flexbox布局…

    2025年12月24日
    000
  • 从零开始的CSS开发项目经验:从布局到样式的完美呈现

    作为现代Web开发的基本技能之一,CSS的设计和开发能力在许多前端工作中都扮演着关键的角色。然而,随着技术的不断发展,CSS也变得更加复杂和灵活,如何从零开始进行CSS开发成为了许多初学者的难题。在这篇文章中,我们将分享一些从零开始的CSS开发项目经验,帮助大家从布局到样式的完美呈现。 一、布局设计…

    2025年12月24日
    000
  • CSS技巧:如何实现居中对齐的布局

    CSS技巧:如何实现居中对齐的布局 在网页设计中,居中对齐的布局经常被使用。无论是居中对齐文字、图片、还是整个页面布局,都可以通过CSS来实现。本文将介绍几种实现居中对齐的布局的CSS技巧,并提供具体的代码示例。 首先,我们来看如何实现水平居中对齐的布局。下面是一些常见的元素的代码示例: 文字居中对…

    2025年12月24日
    000
  • CSS 超链接属性解析:text-decoration 和 color

    CSS 超链接属性解析:text-decoration 和 color 超链接是网页中常用的元素之一,它能够在不同页面之间建立连接。为了使超链接在页面中有明显的标识和吸引力,CSS 提供了一些属性来调整超链接的样式。本文将重点介绍 text-decoration 和 color 这两个与超链接相关的…

    2025年12月24日
    000
  • CSS布局教程:实现瀑布流式卡片布局的最佳方法

    CSS布局教程:实现瀑布流式卡片布局的最佳方法 引言:在现代网页设计中,瀑布流式卡片布局是非常流行的一种布局方式。它能够有效地展示大量的内容,并且在不同的屏幕尺寸下都能够自适应,给用户带来良好的浏览体验。本文将介绍实现瀑布流式卡片布局的最佳方法,并提供具体的代码示例。 一、实现瀑布流式布局的原理 瀑…

    2025年12月24日
    000
  • 如何通过CSS写出适配不同屏幕尺寸的响应式布局

    如何通过CSS写出适配不同屏幕尺寸的响应式布局 在今天的移动互联网时代,人们使用各种设备来访问网页,如智能手机、平板电脑、笔记本电脑等。这使得我们开发网页时,需要考虑不同屏幕尺寸的设备,同时提供优秀的用户体验。为了实现这一目标,响应式布局成为了一个非常重要的概念。 响应式布局是一种通过使用CSS媒体…

    2025年12月24日
    000
  • CSS布局技巧:实现全屏滚动效果的最佳实践

    CSS布局技巧:实现全屏滚动效果的最佳实践 在现代网页设计中,全屏滚动效果成为了一种非常流行的页面交互方式。通过全屏滚动,可以使网页内容以页面为单位进行切换,给用户带来更加流畅和视觉上的丰富体验。本文将介绍一些CSS布局技巧,帮助开发者实现全屏滚动效果的最佳实践。 HTML布局结构在实现全屏滚动效果…

    2025年12月24日
    000
  • CSS布局教程:实现流体布局的最佳方法

    CSS布局教程:实现流体布局的最佳方法 引言:在Web开发中,布局是一个关键的概念。一个好的布局能够使网页看起来整洁、美观,并且在不同设备上都能完美呈现。而其中一种常见的布局方式就是流体布局。本文将介绍如何使用CSS实现流体布局,并提供具体的代码示例。 什么是流体布局?流体布局是指网页布局可以根据浏…

    2025年12月24日
    000
  • CSS Positions布局与网页导航的优化技巧

    CSS Positions布局与网页导航的优化技巧 在网页设计与开发中,布局和导航是两个非常重要的方面。合理的布局可以使网页看起来整洁、美观,而优化的导航则可以提高用户的体验和效率。在这篇文章中,我们将介绍CSS Positions布局和网页导航的一些优化技巧,并提供具体的代码示例。 一、CSS P…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信