移动端响应式

一、css3的@media媒体查询

1、定义和使用

@media 可以针对不同的屏幕尺寸设置不同的样式,特别是如果你需要开发响应式的页面,@media 是非常有用的。当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面,这对调试来说是一个极大的便利。

语法:

  @media mediaType and|not|only (media feature) {
    /*CSS-Code;*/
  }

参数解释:

    mediaType(媒体类型):类型有很多,常用screen,用于电脑屏幕,平板电脑,智能手机等;

    media feature:常用如下两种值:

      max-width:定义输出设备中的页面最大可见区域宽度;

      min-width:定义输出设备中的页面最小可见区域宽度;

2、开始编写响应式页面

a、准备工作一:设置Meta标签

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

参数解释:

      width=device-width:宽度等于当前设备的宽度;

      initial-scale=1.0:初始的缩放比例(默认设置为1.0)

      user-scalable=no:用户是否可以手动缩放(设置为no,我们不希望用户放大缩小页面);

b、准备工作二:加载兼容文件JS,因为IE8不支持HTML5和CSS3 的@media,所以需要加载两个JS文件,来保证我们的代码实现兼容效果

  <!--[if lt IE 9]>
     <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
  <![endif]-->

c、准备工作三:设置IE渲染方式默认为最高(可选),现在有很多人的IE浏览器都升级到IE9以上了,所以这个时候就有又很多诡异的事情发生了,例如现在是IE9的浏览器,但是浏览器的文档模式却是IE8,为了防止这种情况,我们需要下面这段代码来让IE的文档渲染模式永远都是最新的  

    <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">

    PS:这段代码后面加了一个chrome=1,如果用户的电脑里安装了chrome,就可以让电脑里面的IE不管是哪个版本的都可以使用Webkit引擎及V8引擎进行排版及运算,如果没有安装,就显示IE最新的渲染模式。

d、代码示例:

  <!DOCTYPE html>
  <html>
  <head>
    <meta charset="UTF-8">
       <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
       <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
       <title>响应式页面</title>
       <!--[if lt IE 9]>
      <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
         <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
       <![endif]-->

    <style>
         @media screen and (min-width: 1200px){
        body{
          background-color: red; // 屏幕宽度大于等于1200px时生效
                 }
              }

            // 屏幕宽度大于等于800px,小于等于1200px时生效
      @media screen and (min-width: 800px) and (max-width: 1200px){
        body{
          background-color: green;
          }
        }

      @media screen and (max-width: 800px) {
        body{
          background-color: yellow;  // 屏幕宽度小于等于800px时生效
                 }
              }
    </style>
  </head>
  <body>

  </body>
  </html>

二、移动端单位介绍

CSS中,W3C文档把尺寸单位划为为两类:相对长度单位和绝对长度单位。

相对长度单位按照不同的参考元素,又可以分为字体相对单位和视窗相对单位:

字体相对单位有:em、ex、ch、rem;

视窗相对单位则包含:vw、vh、vmin、vmax几种;

绝对单位则是固定尺寸,它们采用的是物理度量单位:cm、mm、in、px、pt以及pc。但在实际应用中,我们使用最广泛的则是px、百分比(%)、em以及rem来度量页面元素的尺寸。

px:绝对(固定)单位;

缺点:任何情况下都是固定值,会导致布局在不同尺寸下的设备错位;

%:相对单位(会有影响发生变化)相对于父级(自身)大小进行定位;

缺点:能确定范围的还是比较好计算的,对于不太好确定值得地方不好使用百分比,并且会导致变形,高度一般不好控制;

em:相对单位 (会有影响发生变化) em=当前字体大小;

缺点:会根据当前容器字体大小发生变化,假如每个容器字体大小不一致,那么计算会非常麻烦;

rem:(r = root)相对单位,只依赖html字体大小;

优点:响应式布局中应用;

示例:动态的修改根元素font-size的js代码:

/* 自执行函数
   * 获得页面宽度后动态修改html上的fontsize
   * 320为iphone5设计稿下的页面宽度,如下设置后的页面在iphone5等宽屏幕上
   * html的font-size会变为100px,即 1rem = 100px    1px=0.01rem
   * 所以设置元素尺寸的时候,如果测量设计稿 15px  则需设置尺寸为 (0.01*15)rem = 0.15rem
   */

  !(function(doc, win) {
    var docEle = doc.documentElement;
    evt = "onorientationchange" in window ? "orientationchange" : "resize";
    fn = function() {
      var width = docEle.clientWidth;
      console.log(width)
      width && (docEle.style.fontSize = 100 * (width / 320) + "px");
    };

    win.addEventListener(evt, fn, false);
    doc.addEventListener("DOMContentLoaded", fn, false);

  }(document, window));

  

  

  

  

  

原文地址:https://www.cnblogs.com/xihuanniya/p/9985484.html

时间: 2024-08-28 00:15:30

移动端响应式的相关文章

基于rem的移动端响应式适配方案(详解) 移动端H5页面的设计稿尺寸大小规范

基于rem的移动端响应式适配方案(详解) : https://www.jb51.net/article/118067.htm 移动端H5页面的设计稿尺寸大小规范 http://www.tuyiyi.com/v/53039.html 原文地址:https://www.cnblogs.com/bydzhangxiaowei/p/9536126.html

【CSS-移动端响应式布局详解】

背景 移动端响应式布局开发主要方案有: 基于rem开发 基于媒体查询 基于弹性盒 基础概念 在讨论响应式布局知识前,先了解下移动端常用基础概念. 逻辑像素(CSS pixels) 浏览器使用的抽象单位,主要用来在网页上绘制内容:通常在我们实际开发中涉及到的CSS单位px都是指逻辑像素. 设备像素或物理像素(Device Pixels) 显示屏幕的最小物理单位,每个DP包含自己的颜色.亮度.等值的 CSS pixels在手机屏幕上占多大的位置,这不是固定的,这取决于很多属性:经过分析和总结,我们可

web前端-移动端响应式与自适应

一. 在HTML的头部加入meta标签 在HTML的头部,也就是head标签中增加meta标签,告诉浏览器网页宽度等于设备屏幕宽度,且不进行缩放,代码如下: <meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1.0,maximum-scale=1.0,minimum-scale=1.0"> 简单分析一下这一行代码的含义:width=device

Java的HTTP服务端响应式编程

为什么要响应式编程? 传统的Servlet模型走到了尽头 传统的Java服务器编程遵循的是J2EE的Servlet规范,是一种基于线程的模型:每一次http请求都由一个线程来处理. 线程模型的缺陷在于,每一条线程都要自行处理套接字的读写操作.对于大部分请求来讲,本地处理请求的速度很快,请求的读取和返回是最耗时间的.也就是说大量的线程浪费在了远程连接上,而没有发挥出计算能力.但是需要注意一点,线程的创建是有开销的,每一条线程都需要独立的内存资源.JVM里的-Xss参数就是用来调整线程堆栈大小的.而

移动端响应式的基础设置

这里是基础配置 蓝色加粗加大绿色背景部分是最关键的,其他的都是辅助 1 @charset "utf-8"; 2 html { 3 font-size: 625%; 4 } 5 body,h1,h2,h3,h4,p,ul,ol,form,fieldset,figure { 6 margin: 0; 7 padding: 0; 8 } 9 body { 10 background-color: #fff; 11 font-family: "Helvetica Neue"

移动端响应式布局

<script> var pixclPation = 1/window.devicePixelRation; document.write('<meta name="viewport" content="width=device-width,initial-scale='+pixelRatio+',minimum-scale='+pixelRatio+',maximum-scale='+pixelRatio+'" />'); </scr

移动端响应式布局+rem+calc()

1.媒体查询:@media only screen and (max-width: ) {},在最初做pc端时,使用各种媒体查询,因为pc的屏幕分辨率总共就几种,不嫌麻烦的重复使用类名.有很大的缺陷就是UI给的设计稿宽度是一定的,在做响应式式凭借自己的感觉是一种超级不爽的美感纠结症. 2.百分比:百分比也是相当的麻烦,还要去各种计算,不是程序员该做的笨重事. 3.em:缺陷是父盒子的百分比. 自己探索了一条自己选择走的捷径,不用在担心宽度和高度不等比例适应,也不用担心在各分辨率下的布局会出现问题

第一课 移动端&amp;响应式

一.调试工具介绍(Chrome Emulation) 1.Device(设备相关) 自定义尺寸.Network(网络模拟).UseAgent(浏览器信息).缩放 2.Media(媒体) 3.Network(网络模拟) 4.Senors(传感器) 经纬度.陀螺仪 二.本地服务器搭建 1.搭建服务器 || HBuilder 2.同一网络下用设备连接 *关闭防火墙 三.像素比 1.点 point(抽象单位) 2.像素渲染(栅格化) 3.物理像素(调整大小) 4.dpi.ppi 5.获取像素比(wind

移动端响应式布局,rem动态更新

(function(){ var fontSizeMatchDeviceWidth = function(){ var deviceWidth = document.documentElement.clientWidth || window.screen.width || 320, devicePixelRatio = window.devicePixelRatio || 1, fontSize = (Math.ceil(deviceWidth * 16 / 320)), scale = 1 /