最新文章专题视频专题问答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
当前位置: 首页 - 科技 - 知识百科 - 正文

怎样让移动端的网页内容自适应

来源:懂视网 责编:小采 时间:2020-11-27 15:26:56
文档

怎样让移动端的网页内容自适应

怎样让移动端的网页内容自适应:这次给大家带来怎样让移动端的网页内容自适应,移动端的网页内容自适应的注意事项有哪些,下面就是实战案例,一起来看一下。终于完成了手头的项目,失踪人口又回归啦!在做项目的过程中,遇到很多值得思考的点,速速道来。 第一个遇到的就是网页大小自适应的
推荐度:
导读怎样让移动端的网页内容自适应:这次给大家带来怎样让移动端的网页内容自适应,移动端的网页内容自适应的注意事项有哪些,下面就是实战案例,一起来看一下。终于完成了手头的项目,失踪人口又回归啦!在做项目的过程中,遇到很多值得思考的点,速速道来。 第一个遇到的就是网页大小自适应的

这次给大家带来怎样让移动端的网页内容自适应,移动端的网页内容自适应的注意事项有哪些,下面就是实战案例,一起来看一下。

终于完成了手头的项目,失踪人口又回归啦!在做项目的过程中,遇到很多值得思考的点,速速道来。 第一个遇到的就是网页大小自适应的问题。

目前比较常用的方法有:

? 首先要让页面大小铺满屏幕又不能溢出。只需要在html<head>标签内加入viewport(如下),参数分别表示:页面宽度= 屏幕宽度,最大和最小伸缩比都是1,不允许用户拉缩。

<meta name="viewport" content="width=device-width,maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">

? 百分比自适应:把长度单位转换为百分比来表示,这样在不同的宽度下,元素的长宽也会随之变化。

优点:宽度之间无缝衔接, 操作起来也相对比较方便。

缺点:字体大小需要另外一套自适应方法来调整;当屏幕宽度大于700px后,继续按照百分比元素会偏大,这个时候调整起来会比较麻烦。

?rem、em自适应 :用媒体查询的方法,确定在不同屏幕宽度下,改变<html>或<body>的fontsize。再用rem, em替代 px作为单位实现自适应。

优点:可以根据不同屏幕宽度来设置,可以完美解决上面说的屏幕偏大时的比例问题。字体的大小也不存在问题。

缺点:根据宽度区间来设置,无法实现无缝变换。

--------------------------------------------------------------------------------

这些兼容方法各有优缺点,都不算完美,怎样才能把优点结合在一起,同时避免缺点呢?

在参考淘宝网的自适应方法时,偶然发现页面<html>的fontsize会根据屏幕的宽度自动调整,而且屏幕宽度和所设字体大小的商是一定的。

于是猜想它是用JS获取屏幕宽度后,按照固定比例缩小后作为rem的单位长度实现自适应。

这不就是优点全有滴解决方法吗!?请容许我激动一下下(☆_☆)

--------------------------------------------------------------------------------

JS代码写起来非常简单,而且完美解决了用rem来设置无法达到无缝衔接的问题。

但移动端测试后问题就出现了,移动端safari在html加载完毕之前将JS以迅雷不及掩耳盗铃之势执行了,在页面没有按照viewport设置好宽度前,JS就读取了错误的宽度,导致元素变成原来的两倍大0^0, 需要用setTimeout()解决问题。

--------------------------------------------------------------------------------

最终代码

Zepto(function($){ 
 var win = window, 
 doc = document; 
 
 function setFontSize() { 
 var winWidth = $(window).width(); 
 // 640宽度以上进行限制 
 var size = (winWidth / 640) * 100; 
 doc.documentElement.style.fontSize = (size < 100 ? size : 100) + 'px' ; 
 }; 
 
 //防止在html未加载完毕时执行,保证获取正确的页宽 
 setTimeout(function(){ 
 // 初始化 
 setFontSize(); 
 
 }, 200); 
 
});

最后补充用rem做自适应过程中发现的一个坑--当html设置较大的fontsize时,块元素内的行内元素margin、padding会出现额外的值,解决办法是把外面包的块元素fontsize设置为0。

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

相关阅读:

table表格中的内容溢出应该如何处理

怎么实现获取textarea的动态剩余字数

html关于PHP你必须知道的重要知识点

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

文档

怎样让移动端的网页内容自适应

怎样让移动端的网页内容自适应:这次给大家带来怎样让移动端的网页内容自适应,移动端的网页内容自适应的注意事项有哪些,下面就是实战案例,一起来看一下。终于完成了手头的项目,失踪人口又回归啦!在做项目的过程中,遇到很多值得思考的点,速速道来。 第一个遇到的就是网页大小自适应的
推荐度:
标签: 设置 如何让 如何
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top