用6数字域名做网站的是,网业翻译成中文,江门英文网站建设,网站模板下载简单的那种前话
好久没写教程了#xff08;可能会误导新手的菜鸟教程(#xffe3;▽#xffe3;)#xff09;。 这是我的github#xff0c;欢迎前端大大们和我一起学习交流 https://github.com/pwcong 最近入职公司做前端实习#xff0c;这几个星期来学到了移动端H5页面适配…前话
好久没写教程了可能会误导新手的菜鸟教程(▽)。 这是我的github欢迎前端大大们和我一起学习交流 https://github.com/pwcong 最近入职公司做前端实习这几个星期来学到了移动端H5页面适配。以前根本没做过移动端网页/(ㄒoㄒ)/~~还是微信端的
所以把我学到的一个小知识点写下来也分享给前端新手们。 正文
0x00 大概说明
做移动端网页和pc端很大不同的便是现在移动端窗口分辨率繁多。
很多时候UI给的设计图只有一份还是按照iphone6设计的这就让前端适配其他例如6plus或安卓等其他移动端头疼。
还好阿里巴巴2015年底公开了其成熟的适配方案
lib-flexible至于其可靠性可参考每年天猫活动的移动端页面。这个方案的用法大概是这样的HTML 头部引入
lib-flexible 的样式和js库容器或组件宽高主要使用单位
rem 字体大小则不变仍然使用单位
px。还有一个约束是因为只面向移动端因此我们限制最外层包裹的div最大宽度为 640px 我这里只简单介绍怎么使用 lib-flexible 实现移动端适配如果需要深入解释的知识请阅读如下文章 https://github.com/amfe/article/issues/17 0x01 引入 lib-flexible
最新的库文件可以到这里下载 https://github.com/amfe/lib-flexible
clone 下来后在
build 目录下找到
flexible.css 和
flexible.js 在HTML头部引入即可例如!DOCTYPE html
html langzh-CNheadtitlelib-flexible demo/titlemeta charsetUTF-8meta nameviewport contentwidthdevice-width,initial-scale1,maximum-scale1,user-scalableno...link hrefcss/flexible.css relstylesheetscript srcjs/flexible.js/script/headbody.../body/html
0x02 计算rem值
谷歌
rem 的用法后很多人应该大概了解
rem 的原理了大概就是
rem 依赖
font-size 的值例如默认下
1rem 16px因此通过在不同分辨率修改
font-size 就可以达到适配不同分辨率的移动端了。需要详细了解 rem 值计算可参考这篇文章 http://www.cnblogs.com/azhai-biubiubiu/p/6003597.html rem 来做宽高定型有个最大的问题是
font-size 如何计算的问题如何算得的
font-size 可以在不同分辨率下显示效果一致呢不用担心
lib-flexible 已经帮你算好了在你调整窗口大小的时候自动计算调整
rem 的基准你只要做的是按照设计图算出能适配不同分辨率的移动端的
rem 值。这里有个关系图 看不懂没关系看那么多flexible的教程都放了我也就跟着放出来好了。
假如UI给了这个设计图找不到工作的UI (/▽)
好我这辣鸡一眼看出了
这是以iphone5为标准的ui设计稿设备窗口宽度为 640px中间一个色块居中背景色为 #0075a9margin-top 为 100px width 为 240pxheight 为 120px
接下来我们来计算rem值计算公式很简单 需转换的px值 / 设计稿宽度px值 * 10 上面的尺寸计算一下转换成下面的说法
这是以iphone5为标准的ui设计稿设备窗口宽度为 10rem中间一个色块居中背景色为 #0075a9margin-top 为 1.5625rem width 为 3.75remheight 为 1.875rem
0x03 按照找不到工作的UI给的设计稿敲出代码
!DOCTYPE html
html langenheadtitle/titlemeta charsetUTF-8meta nameviewport contentwidthdevice-width, initial-scale1link hrefcss/flexible.css relstylesheetscript srcjs/flexible.js/scriptstylehtml, body{width: 100%;height: 100%;position: relative;padding: 0;margin: 0;overflow: hidden;}body{background: #333;}.container{overflow-x: hidden;overflow-y: auto;position: relative;height: 100%;max-width: 640px;background-color: white;margin: 0 auto;}.block{margin: 0 auto;margin-top: 1.5625rem;width: 3.75rem;height: 1.875rem;background-color: #0075a9;}/style/headbodydiv classcontainerdiv classblock/div/div/body/html0x04 不同分辨率移动端下浏览效果 可以看到在多个不同设备间效果基本差不多 后话
也许你会说我这个案例 内容太少没有什么说服力。
那么大佬们快动起手来在你的移动端网页项目中用上
lib-flexible 看看能否解决移动端页面适配问题吧。