最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

产品经理学技术:移动Web怎么做屏幕适配(一)_html/css_WEB-ITnose

来源:懂视网 责编:小采 时间:2020-11-27 16:22:39
文档

产品经理学技术:移动Web怎么做屏幕适配(一)_html/css_WEB-ITnose

产品经理学技术:移动Web怎么做屏幕适配(一)_html/css_WEB-ITnose:【文章摘要】有段时间没有更新了,最近打算发一些硬一点的东西, 产品经理 学技术系列。 产品经理要不要懂技术的问题已经无需再讨论了,希望产品经理们可以从这些文章里,学到一点儿技术原理。 相关概念: viewport:屏幕可见区域,你可以理解成显示屏幕大
推荐度:
导读产品经理学技术:移动Web怎么做屏幕适配(一)_html/css_WEB-ITnose:【文章摘要】有段时间没有更新了,最近打算发一些硬一点的东西, 产品经理 学技术系列。 产品经理要不要懂技术的问题已经无需再讨论了,希望产品经理们可以从这些文章里,学到一点儿技术原理。 相关概念: viewport:屏幕可见区域,你可以理解成显示屏幕大

【文章摘要】有段时间没有更新了,最近打算发一些硬一点的东西, 产品经理 学技术系列。

产品经理要不要懂技术的问题已经无需再讨论了,希望产品经理们可以从这些文章里,学到一点儿技术原理。

相关概念:

viewport:屏幕可见区域,你可以理解成显示屏幕大小。

1

移动端适配一般指网页适配多种尺寸屏幕,让网页效果看起来和设计师的设计稿一样。说白了就是同一套代码在不同分辨率的手机上跑时,页面元素间的间距,留白,以及图片大小会随着变化,在比例上跟设计稿一致,达到最优的视觉效果。

图1. 260*400的屏幕

图2. 380*400的屏幕

上面页面在不同大小屏幕上的展现,乍一看没什么问题,一般的工程师会认为已经OK了,所以前端工程师很容易忽略屏幕适配。但如果你是抠细节体验的产品经理,你可能会发现如下问题:

图1的屏幕的尺寸较小,因此头像应该小些,话题左边的空白也应该小一些。

图片应该保持正方形,而且两张图之间的边距应该随屏幕变化而变化

说白了,就是没有做好不同屏幕的适配,在某些屏幕下的视觉效果未能达到最优。

2

本文章只关注如何适配,所以先只谈结论,后面有机会可以讲讲viewport和css像素px中的细节。

网页在viewport中布局,viewport被分成一个个小方块,一个CSS像素占一个方块

在设置了viewport宽度等于设备宽度的情况下,通过某种算法,在不同大小的屏幕上,1个CSS像素所占屏幕的物理尺寸是一样大的

长度单位rem是相对于html标签的font-size(字体尺寸)的。例如html标签设置font-size:36px,同时div设置width:1.2rem。那么这个div的宽度就是1.2rem=36px*1.2=43.2px

如上面的例子,如果加载页面的时候,使用JS根据屏幕的大小动态设置html标签的font-size,随着html标签font-size的值变化,div的1.2rem换算成px的值 也跟着变化,即实现了div随屏幕大小变化而变化,而CSS代码始终是width:1.2rem。以此类推到页面所有的元素。

3

业内比较流行的做法(参考阿里的flexible),有以下要点:

设置viewport为设备宽度(这里不一定,但目前先这样足矣)

将viewport分成10rem,并计算出1rem在当前浏览器的像素值,把它赋予html标签的font-size(分成10rem只是为了方便计算而已)

写CSS代码时,遇到要适配的地方,比如width,margin,padding等,就不要再用px了,改成用rem

JS和Html代码如下:

CSS代码做了类似如下的修改:

运行结果如下:边距和头像图片都随屏幕变化而变化了

看不懂代码没关系,简单解释下就是,在HTML页面加载完成之后,把页面宽度等分为若干份(这里是10份),比如页面宽度是W 像素,则 1rem = W/10 像素,后面所有用到宽度的地方,都用 rem 来换算。比如外边距、内边距等。

4

现有设计师提供宽度为400px的设计稿,其中某个图片的宽度设计为20px,那么,CSS的写法就是img{width: 0.05rem;},怎么得出这个结果的呢?

  1. 设计稿的宽度视同手机宽度,即假设有一个viewport为400px的手机
  2. 将它分成10rem,每个rem为40px;
  3. 那么图片宽度20px自然就是0.5rem;

且慢,岂不是意味着,每次写到尺寸的地方,我都要先在草稿纸上把设计师给的px换算成rem?别急,sublime text 3有一款插件可以帮助你进行这个换算,你只需要输入20px,它会自动帮你换算成 0.5rem,看以下图就秒懂了

看吧,工程师手上很多工具,可以提高效率的呢~

本文由 产品100 为你推荐并呈现

文章来源:微信公众号:程序员和产品经理(devpdm)

文章作者:啃先生

友情提示:

若出处标注错误,请联系QQ:2977686517及时更正,感谢理解和支持!

少年关注我们的官方微博@产品100和微信订阅号:chanpin100ghsd,有惊喜哦!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

产品经理学技术:移动Web怎么做屏幕适配(一)_html/css_WEB-ITnose

产品经理学技术:移动Web怎么做屏幕适配(一)_html/css_WEB-ITnose:【文章摘要】有段时间没有更新了,最近打算发一些硬一点的东西, 产品经理 学技术系列。 产品经理要不要懂技术的问题已经无需再讨论了,希望产品经理们可以从这些文章里,学到一点儿技术原理。 相关概念: viewport:屏幕可见区域,你可以理解成显示屏幕大
推荐度:
标签: 屏幕 如何 学习
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top