zoukankan      html  css  js  c++  java
  • 响应式页面@media介绍和移动端单位介绍

    一.响应式页面-@media介绍

    1.css3的@media查询

      定义和使用

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

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

    screen: 用于电脑屏幕,平板电脑,智能手机等。(最常用) speech 应用于屏幕阅读器等发声设备 媒体功能

    media feature:

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

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

    开始编写响应式页面

    准备工作1:设置Meta标签

    首先我们在使用 @media 的时候需要先设置下面这段代码,来兼容移动设备的展示效果:

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

    参数解释: 

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

    initial-scale:初始的缩放比例(默认设置为1.0,即代表不缩放)

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

    准备工作2:加载兼容文件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]-->

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

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

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

    1、如果文档宽度大于等于 1170px 则应用花括号内的样式——修改body的背景颜色(background-color):

    @media screen and (min- 1170px) {
        body {
            background-color:lightblue;
        }
    }

    2.如果文档宽度大于等于 992px 则应用花括号内的样式——修改body的背景颜色(background-color):

    @media screen and (min- 992px) {
        body {
            background-color:red;
        }
    }

    3、当文档宽度大于等于 768px 并且小于等于992px ( width >=768 && width <=992)的时候显示的样式:

    @media screen and (min-768px) and (max-992px) {
        /* CSS 代码 */
    }
    <!DOCTYPE html>
    <html lang="en">
    <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- 1200px){
                body{
                    background-color: red;
                }
            }
    
            @media screen and (min- 800px) and (max- 1200px){
                body{
                    background-color: green;
                }
            }
    
            @media screen and (max- 800px) {
                body{
                    background-color: yellow;
                }
            }
        </style>
    </head>
    <body>
        
    </body>
    </html>
    @ media
    <!doctype html>
    <html lang="en">
    <head>
      <meta charset="utf-8">
      <title>jQuery UI 排序(Sortable) - 默认功能</title>
      <link rel="stylesheet" href="./css/jquery-ui.css">
      <script src="./js/jquery-1.9.1.js"></script>
      <script src="./js/jquery-ui.js"></script>
      <link rel="stylesheet" href="./css/style.css">
      <style>
      #sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
      #sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
      #sortable li span { position: absolute; margin-left: -1.3em; }
      </style>
      <script>
      $(function() {
        $( "#sortable" ).sortable();
        $( "#sortable" ).disableSelection();
      });
      </script>
    </head>
    <body>
     
    <ul id="sortable">
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 1</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 2</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 3</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 4</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 5</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 6</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 7</li>
    </ul>
     
     
    </body>
    </html>
    jQueryUI
    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <link rel="stylesheet"
      href="https://cdn.jsdelivr.net/npm/animate.css@3.5.2/animate.min.css">
      <style>
          #box{
              width:200px;
              height: 200px;
              line-height: 200px;
              text-align: center; 
              background-color: green;
              color: #fff;
              position: absolute;
              top: 1000px;
          }
      </style>
    </head>
    <body style="height: 2000px;">
    
        <div id="box"  class="animate bounceOutLeft">wusir</div>
        <script src="jquery.js"></script>
    
        <!-- <h2 class="animated fadeOutRight delay-2s">alex</h2> -->
        <script>
            
            $(function () {
                // $('#box').addClass('animated bounceOutLeft');
    
                $(document).scroll(function () {
                    
                    console.log($(this).scrollTop());
    
                    var scrollTopHeight = $(this).scrollTop();
    
                    if (scrollTopHeight >= 1000) {
                         $('#box').addClass('animated slideInDown');
    
                    }
                })
            });
        </script>
    </body>
    </html>
    animate

    二.移动端单位介绍

    1.字体相对单位和视窗相对单位

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

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

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

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

      %:相对定位(会有影响发生变化)相对于父级(自身)大小进行定位
    缺点:能确定范围的还是比较好计算的,对于不太好确定值得地方不好使用百分比,并且会导致变形,高度一般不好控制

      em: 相对定位 (会有影响发生变化) em=当前字体大小
    缺点:会根据当前容器字体大小发生变化,假如每个容器字体大小不一致,那么计算会非常麻
      rem       r==root

    em=字体大小 font-size
    rem 相对单位      只依赖于html字体大小

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no, minimal-ui">
            <title>移动端布局</title>
            <style type="text/css">
    
                /*rem  root*/
                *{
                    padding: 0;
                    margin: 0;
                }
                ul{
                    list-style: none;
                }
                .clearfix:after{
                    content: '';
                    display: block;
                    clear: both;
                }
                html{
                    width: 100%;
                    height: 100%;
                    /*font-size: 100px;*/
                    /*1rem = 10px*/
                    overflow: hidden;
                }
                body{
                    width: 100%;
                    height: 100%;
                    overflow: auto;
                }
                .head-box{
                    width: 100%;
                    height: 0.4rem;
                    background-color: red;
                    position: absolute;
                    top: 0;
                    left: 0;    
                }
                .list{
                    margin-top: 0.4rem;
                    font-size: 16px;
                }
                
                .list .item{
                    float: left;
                    width: 1rem;
                    height: 1rem;
                    border: 1px solid black;
                    margin: 0.1rem;
                    
                }
                
                
                
            </style>
        </head>
        <body>
            
            <header class="head-box">
                <div class="head-top"></div>
                <div class="head-bottom"></div>
            </header>
            
            <ul class="list clearfix">
                <li class="item">1111111</li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
                <li class="item"></li>
            </ul>
            
        </body>
        <script src="./js/resize.js"></script>
    </html>
  • 相关阅读:
    html 父容器和子容器通信
    5.7.13mysql 无法登陆
    c# foreach枚举器
    WPF bitmap转bitmapimage 使用 CreateBitmapSourceFromHBitmap内存泄漏
    c# 另存为excel
    CRC循环校验码
    一般处理程序
    DSS->数仓->数据集市->数据湖->数据中台->商业智能
    常见的消息中间件对比
    Dockerfile详解
  • 原文地址:https://www.cnblogs.com/chenxi67/p/9760664.html
Copyright © 2011-2022 走看看