zoukankan      html  css  js  c++  java
  • HTML移动开发技巧 响应式布局 弹性布局

    移动开发常用技巧

    [viewport基本知识]

    设置布局viewpoint的各种信息
    1、width=device-width;设置viewport视口宽度等于设备宽度
    2、initial-scale=1;网页默认缩放比为1
    3、minimum-scale=1;网页最小缩放比为1
    4、maximum-scale=1;网页最大缩放比为1
    5、user-scalable=no;禁止用户手动缩放网页(iOS10以上的设备失效)

    在手机站以及响应式网站的制作中,网页必须添加下述viewport的设置语句。

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


    禁止设备将手机号、邮箱号进行识别,取消点击拨打电话等事件
    <meta name="format-detection" content="telephone=no,email=no"/>


    ios添加到主屏幕时web主屏幕时,wenApp的标题

    <meta name="apple-mobile-web-app-title" content="标题">

    iOS添加到主屏幕时, 启用webAPP的全屏模式,删除顶端地址栏和底部工具栏
    <meta name="apple-mobile-web-app-capable" content="yes" />

    iOS添加到主屏幕时webAPP的顶部状态栏颜色
    black:黑色
    white:白色
    black-translucent:半透明(当设置为半透明时,网页将充满整个屏幕顶部透明的状态栏将盖住网页最上方一小条)
    <meta name="apple-mobile-web-app-status-bar-style" content="black">

    ios添加到主屏幕时webAPP的图标-

    <link rel=""/>


    设置浏览器使用最新的IE或Chrome去编译
    >>>这句设置语句,不是手机端专用,一般PC网页均需要设置。
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>

    ——————————————————————————————————————————————————————————————————————————

    body{
            		/*[手机端字体样式]
            		 1、 一般手机端不支持微软雅黑字体
            		 2、中文字体一般不设置
            		 3、 英文字体一般设置为font-family:helvetica;*/
            		font-family:helvetica;
            		/*设置用户不能选中文本
            		 1、手机端不能长按选择
            		 2、PC端不能用鼠标选择*/
            		-webkit-user-select: :none;
            		-moz-user-select: none;
            		/*
            		 * 
            		 */
            		
            	}
            	a img{
            		/*禁止超链接和图片长按时弹出菜单*/
            		-webkit-appearance: none;
            	}
            	input{
            		/*去除表单的默认外观,手机PC均可使用*/
            		appearance: none;
            		-webkit-appearance: none;
            		-moz-appearance: none;
            	}
            	/*设置placeholder的属性*/
            	input::-webkit-input-placeholder {
    				color: #999;
    			}
    

      响应式布局

    [使用媒体查询的三种方式]

    {


    1、直接在CSS中使用:


    @media类型(常选all/screen)and(条件1) and(条件2){
    css选择器{
    CSS属性:CSS属性值;
    }
    }
    2、使用link链接CSS,media属性可以设置媒体查询方式
    <link rel="stylesheet" type="text/css" href="css/02-响应式布局.css" media="all and (max-800px)"
    3、 使用import导入:直接在URL后面使用空格间隔媒体查询规则(不经常使用)

    @media screen and (max- 800px) and (min- 500px){
    body{
    background-color: blue;
    font-size: 30px;
    }
    }
    @media only screen and (max- 500px) {
    body{
    background-color: red;
    font-size: 16px;
    }
    }

    ——————————————————————————————————————————————————————————————————————————————————————

    弹性布局

    [弹性布局]
    1、了解两个基本概念:
    容器:需要添加弹性布局的父容器
    项目:弹性布局容器中的每一个子元素。称为项目

    2、弹性布局的使用
    ① 给父容器添加display:flex/inline-flex;属性,即可使容器内容
    使用弹性布局显示。而不遵循常规文档流的显示方式
    ② 容器添加弹性布局后,仅仅是容器内容采用弹性布局,
    而容器自身在文档流中的定位方式依然遵循常规文档流
    ③ display: flex;容器添加弹性布局后,显示为块级元素;
    display: inline-flex;容器添加弹性布局后,显示为行级元素
    ④ 注意,设为 Flex 布局以后,子元素的float、clear和vertical-align属性将失效。
    但是position属性依然生效。


    3、作用于容器的相关属性


    flex-direction属性决定主轴的方向(即项目的排列方向)。
    row(默认值):主轴为水平方向,起点在左端
     row-reverse:主轴在水平方向,起点在右端
     column:主轴为垂直方向,起点在上沿。
     column-reverse:主轴为垂直方向,起点在下沿。

     ② flex-wrap属性 默认情况下,项目都排在一条线(又称"轴线")上。flex-wrap属性定义,如果一条轴线排不下,如何换行
     nowrap(默认):不换行。当容器宽度不够时,每个项目会被挤压宽度
    wrap:换行,第一行在上方
     wrap-reverse:换行,并且第一行在下方。


     ③ flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为flex-flow:row nowrap;


     ④ justify-content属性定义了项目在主轴上的对齐方式。
     >>>此属性与主轴方向息息相关。主轴方向为row-起点在左边 row-reverse:起点在右边 colume:起点在上边 colume-revese:起点在下面

     flex-start(默认值):项目位于主轴起点
    flex-end:项目位于主轴终点
    center: 居中
    space-between:两端对齐,项目之间的间隔都相等。(开头和最后的项目与父容器的边缘没有间隔)
    space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。(开头和最后的项目,与父容器的边缘有一定的间隔)


    align-items属性定义项目在交叉轴上如何对齐
    flex-start:交叉轴的起点对齐。
    flex-end:交叉轴的终点对齐。
    center:交叉轴的中点对齐。
    baseline: 项目的第一行文字的基线对齐。(文字的行高、字体大小会影响基线)
    stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。


    align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。

    (当项目换为多行时可使用可用align-content取代align-items)
    flex-start:与交叉轴的起点对齐。
    flex-end:与交叉轴的终点对齐。
    center:与交叉轴的中点对齐。
    space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
    space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
    stretch(默认值):轴线占满整个交叉轴


    4、作用于项目上的属性


    order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。

    flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。


    flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。


    flex-basis定义项目占据的主轴空间,设置后,如果主轴为水平,则设置这个属性,则相当于设置项目的宽度,原width将会失效。


    flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。

    这个属性有两个快捷设置: auto=(1 1 auto)空间剩余会放大 空间不足会缩小
    none=(0 0 auto)空间剩余不放大 空间不足不缩小


    align-self属性:定义单个项目自身在交叉轴上的排列方式,可以覆盖掉容器上的align-items属性,
    属性值:与align-items相同。默认值为auto;表示继承父容器的align-items属性。

  • 相关阅读:
    php的基础知识(三)
    php的基础知识(二)
    css的基础用法(下)
    css的基础用法(上)
    Conceptual blockbusting--chap7 Kinds of blockbusters
    Conceptual blockbusting--chap6 Alternate thinking languages
    Conceptual blockbusting--chap5 Intellectual and Expressive blocks
    Conceptual blockbusting--chap4 Cultural and Environmental blocks
    Conceptual blockbusting
    Conceptual blockbusting- chap2 perceptual blocks
  • 原文地址:https://www.cnblogs.com/zzzzyy/p/7353712.html
Copyright © 2011-2022 走看看