如何解决PC端和移动端自适应问题?

摘要:
在制作网页时,我们通常需要考虑不同的电脑屏幕大小和不同的手机屏幕大小,以解决改变风格的问题。我们如何解决这个问题?现在我们主要使用自适应技术来解决高度、宽度和图像自适应的问题。现在让我们总结一下PC端和移动端。通常,图像的高度和宽度是自适应的,这通常与页面布局有关。

   做网页时,我们通常需要考虑到不同电脑屏幕尺寸,以及不同手机屏幕大小等问题,解决样式发生改变的情况,那么如何解决呢?现在主要是采用自适应来解决高度,宽度的,以及图片自适应问题,下面就PC端和移动端来总结一下,通常进行自适应高度和宽度,图片时,一般与页面的布局存在关系。

1、最小尺寸分辨率1024*768(传统17寸显示器),则可以采用940px、960px、或者常用的980px作为最小宽度

2、1024*768之后稍大的分辨率就是1280*768了,则可以采用1200px或者1220px作为稍大的网页宽度

3、支持css3、html5的高级浏览器可以利用CSS3 Media Queries让网页在不同分辨率下自动调节布局标签

4、不支持css3、html5的脑残浏览器特别是<=ie8系列则需要用js以及resize事件来控制html的布局标签宽度了

5、宽度自适应需要对每个显示模块进行不同宽度的计算,在做html布局时需要大量的计算与适配。

6、宽度自适应为不同宽度显示器写布局元素时常用的css

下面我们看下,如何用js和css来自适应屏幕的大小。

一:了解高度和宽度的基础

      下面用图片来说明:

      如何解决PC端和移动端自适应问题?第1张

    网页可见区域高宽为:document.body.clientHeight||document.body.clientWidth

    网页正文的区域高宽为:document.body.scrollHeight||document.body.scrollWidth(包括滚轮的长度)

    网页被卷去的上左区域:document.body.scrollTop||document.body.scrollLeft

二: css自适应高度

   1.两栏布局,左边固定,右边宽度自适应

方法一:
//html部分
<
div id="left">左边</div> <div id="bodyText">正文</div> //css部分
*{margin:0;padding:0}
#left{float:left;200px;background:red;}
#bodyText{margin-left:200px;background:yellow;

方法二:
//html部分
<div id="left">左边</div>
<div id="body">
    <div id="bodyText">正文</div>
</div>
//css部分
#left{float:left;200px;background:red;margin-right:-100%;}
#body{100%;float:left;}
#bodyText{margin-left:200px;background:yellow;}

  2.三栏布局,两边定宽,中间自适应宽度

方法一:
<
div id="left">左边</div>----注意和div的位置有关系 <div id="right">右边</div> <div id="center">中间</div>
//css部分
#left{200px;background:red;float:left;}
#center{auto;background:blue;}
#right{200px;background:yellow;float:right;}

方法二:
html部分:
<div id="body">
    <div id="center">中间</div>
</div>
<div id="left">左边</div>
<div id="right">右边</div>
css部分:
#body{100%;float:left;} //设置浮动和100%
#body #center{background:red;margin-left:200px;margin-right:300px;} //margin-left:100%的使用方法
#left{200px;background:yellow;margin-left:-100%;float:left}
#right{300px;background:blue;margin-left:-300px;float:left}
-----如果设置为margin-left:-100%,则会跑到body的左边。
-----如果设置为margin-left:-300px(即right的宽度),则会跑到body的右边

 3.关于最小宽度和最大宽度

   这里依然结合布局来看,如下面的代码:自适应宽度,从而改变布局。

//html部分
<
div id='container'> <div class='one'></div> <div class='two'></div> <div class='three'></div> </div> //css部分 #container{100%;} .one{20%;background:red;} .one,.two,.three{float:left; height:100px;} .two{60%;background:yellow;} .three{20%;background:blue;} @media (max-800px){--如果浏览器小于800px .one{40%;} .two{60%} .three{100%} } @media (max-400px)--如果浏览器宽度小于400px { .one{100%} .two{100%} .three{100%} }

  理解什么叫最小宽度和最大宽度,最小宽度指为元素设置的最小宽度,到达最小宽度后,缩放文本不会起到任何作用

最大宽度是所有元素所能达到的一个上限,不能再继续往上增加。

三: css处理自适应高度

//html部分代码
<div id="fit"></div>
//css代码
html,body{margin:0;height:100%;}
#fit{200px;background:yellow;height:100%;border:1px solid red;}

--这里同时给html和body加样式,是为了兼容各大浏览器。
IE 处于混杂模式时,body以窗口为高度参照,body设置为100%就可以使得页面和窗口一样高,body里面的嵌套div也可以扩展到窗口高度,
这样的话可以使布局适应浏览器窗口大小。窗体 》body》div  (html ,body {overflow:scroll}  一层滚动条)
     但是当处于标准模式时,body以html标签为高度参照,html标签才以窗口为参照,所以仅仅body 100%,并不能使它的子div100% 占据整个屏幕
还要使得 html 100%使得 html获得窗口大小才行。窗体》html》body》div (html ,body {overflow:scroll}  两层滚动条 ,html的滚动条从来不会用到)

 父级随子级高度变化而自适应变化与子级随父级高度变化而变化

<div id="fj">
   我是父级
   <div id="zj1">我是子级1</div>
   <div id="zj2">我是子级2</div>
</div>
//css部分
#fj{border:4px solid red;}
#zj1{border:2px solid yellow;}
#zj2{border:2px solid blue;}----这种情况下,父级高度随着子级div的高度自适应的改变

如果子div使用了float属性,此时已经脱离标准流,父div不会随内容的高度变化而变化,解决的办法是在浮动的div下面,加一个空div,设置clear属性both

<div id="fj">
   我是父级
   <div id="zj1">我是子级11111111111111111111111111</div>
   <div id="zj2">我是子级222222222222222222222222222222222222222222
  222222222222222222222222222</div>
   <div id="clear" style="clear:both"></div>------如果去掉这句话,则父级div高度,不会随着子级的高度变化而变化
</div>
//css部分
#fj{border:4px solid black;}
#zj1{border:2px solid yellow;float:left}
#zj2{border:2px solid blue;float:left}

高度的自适应的方法还有很多,这里不再列举。像height:auto等等。

四:js处理高度和宽度自适应问题

<div id="div1" >222222222222222222222</div>
//js部分
function setHeight(obj)
{
  var temHeight=null;
  //FF
  if(window.innerHeight)
  {
    temHeight=window.innerHeight;//包括页面高度和滚动条高度
  }
  else 
  {
     temHeight=document.body&&document.body.clientHeight;
  }
  if(temHeight>document.body.clientHeight)//页面高度
  {
     oDiv.style.height=temHeight+"px";
  }
  else
  {
    oDiv.style.height=document.body.clientHeight+"px";
  }
}
window.onload=function()
{
  var oDiv=document.getElementById("div1");
  getHeight(oDiv);
}

宽度自适应代码:

function  setWidth(obj)
{ var screenWidth = window.screen.width; var width; var imgURL ; if (screenWidth >= 1440)
{ width = "1400px"; imgURL = "1400.png";//设置不同分辨率下的图片 }
else if (1024
< screenWidth && screenWidth < 1440)
{ width
= "1200px"; imgURL = "1200.png"; }
else { width
= "980px"; imgURL = "980.png"; } obj.style.width=width ;
obj.style.backgroundImage="url(" + imgURL + ")"; })

 五:移动端的自适应高度和宽度

     移动端的相对要简单些,首先,在网页代码的头部,加入一行viewport标签。

    <meta name=”viewport” content=”width=device-width, initial-scale=1″ />

     viewport是网页默认的宽度和高度,上面的意思表示,网页的宽度默认等于设备屏幕的宽度,原始缩放比例为1,即网页初始大小占屏幕面积的100%。

    1:由于网页会根据屏幕宽度调整布局,所以不能使用绝对宽度的布局,也不能使用具有绝对宽度的元素。这一条非常重要。具体说,CSS代码不能指定像素宽度:xxx px;只能指定百分比宽度: xx%;或者auto;

    2:一般使用em,尽量少使用px字体

    3:使用流动布局

    4:自适应网页设计”的核心,就是CSS3引入的media query模块。下载地址:http://download.csdn.net/download/song_121292057/8031781

    自动探测屏幕宽度,然后加载相应的CSS文件。

    <link rel="stylesheet" type="text/css"  media="screen and (max-device- 400px)" href="style.css" /> 

-------当屏幕小于400时,就加载style.css这个文件

  5:除了用html标签加载CSS文件,还可以在现有CSS文件中加载。

  @import url("style2.css") screen and (max-device- 800px);//当小于800px屏幕时,就加载style2.css文件

  6:图片的自动缩放,比较简单。只要一行CSS代码:img{ max- 100%;}建议根据不同的屏幕分辨率,加载不同大小像素的图片。      

    移动端的自适应,大体上差不多就这么多,主要核心是利用mediaquery,根据不同的屏幕大小,实现不同的布局。代码可看上面的列子。这里不再重复写。


大概总结了一下自己遇到的问题,还有什么好的方法,请给我留言哈!

作者:向婷风

出处:http://www.cnblogs.com/jtjds/p/5480857.html

如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者

本人同意 转载文章之后必须在 文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。

 


    

    

免责声明:文章转载自《如何解决PC端和移动端自适应问题?》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇docker 下载安装镜像python 连接oracle数据库:cx_Oracle下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

用css3绘制你需要的几何图形

1、圆形 示例:          思路:给任何正方形元素设置一个足够大的 border-radius ,就可以把它变成一个圆形.代码如下: html: <div class="size example1"></div> css: .size{ 200px; height: 200px; backgro...

bootstrap基础(六)

其他内置组件 一、缩略图 使用方法: 通过“thumbnail”样式配合bootstrap的网格系统来实现。 <div class="container"> <div class="row"> <div class="col-xs-6 col-md-3"> <a hr...

微信小程序开发系列(一)小程序开发初体验

开发小程序所需的基本技能 关于小程序的介绍和使用场景这里不作介绍,这个系列的文章会一步一步地带领大家快速地学习和掌握小程序的开发。 关于还没有接触过小程序的开发者来说,最关心的问题无非就是,开发小程序,我需要掌握哪些技能? 从我学习小程序的经验中得出,开发小程序的基本要求: 如果你是一名已经工作1年以上的前端工程师,你几乎不用学习任何新的东西就可以快速上手...

CSS或者JS实现鼠标悬停显示另一元素

想达到鼠标悬停到元素a上,显示另一个元素b,可以通过css实现也可以通过js实现。js:写两个函数:mouseenter,mouseleave,例如:其中 $("#a").mouseenter(function() { $("#b").show("normal"); }); $("#a").mouseleave(function() { $("#b").h...

CSS 实现左侧固定,右侧自适应两栏布局的方法

"左边固定,右边自适应的两栏布局",其中有老生常谈的float方法,BFC方法,也有CSS3的flex布局与grid布局。并非所有的布局都会在开发中使用,但是其中也会涉及一些知识点。 常用的宽度自适应的方法通常是利用了block水平的元素宽度能随父容器调节的流动特性。另外一种思路是利用CSS中的calc()方法来动态设定宽度。还有一种思路是,利用CSS3中...

HTML参考 :TBODY元素 详解

TBODY 元素内包含的有效标签有:TD TH TR TBODY 元素会为全部表格自动定义,就算表格没有显式定义 TBODY 元素。 table 对象及其相关的元素有独立的表格对象模型,这与常规对象模型所采用的方法有很大不同。 此元素在 Microsoft? Internet Explorer 3.0 的 HTML 中可用,在 Internet Expl...