zoukankan      html  css  js  c++  java
  • writing-mode属性

    writing-mode属性 最初只是ie中的属性,只有ie支持,现在在css3中谷歌,火狐也开始支持。

    所以使用的时候就需要记住两套不同的语法,ie的私有属性和css3的规范属性

    如果只需要兼容到ie8+就可以只使用css3的规范属性就可以了

    css3:

    writing-mode:horizontal-tb;//默认:水平方向,从上到下
    writing-mode: vertical-rl;//垂直方向,从右向左
    writing-mode:  vertical-lr;//垂直方向,从左向右
    ie私有属性:
    主要的:
    writing-mode: lr-tb ;//从左到右,从上到下。默认
    writing-mode: tb-rl;//从上到下,从右向左
    writing-mode:tb-lr (IE8+);//水平方向,从上到下,从左到右

    如果你的项目需要兼容IE7,则只有关注这两个值就可以了:初始值lr-tbtb-rl,对应于CSS3规范中的horizontal-tbvertical-rl

    writing-mode属性和float属性有些类似(元素的宽度和高度由子元素撑起来),原本设计的是控制内联元素的显示的;就是文字的显示

    writing-mode将页面默认的水平流改成了垂直流
    1. 水平方向也能margin重叠
    css
    .demo {
                -webkit-writing-mode: vertical-lr;
                -ms-writing-mode: vertical-lr;
                writing-mode: tb-lr;
                margin-bottom: 20px;
    
            }
    
            .demo .div1, .demo .div2 {
                margin: 0 20px;
                background-color: red;
            }

    html

    <div class="demo">
        <div class="div1">水平方向margin重叠</div>
        <div class="div2">水平方向margin重叠</div>
    </div>


    2. 可以使用margin:auto实现垂直居中
    css
    .demo1 {
                height: 300px;
                background-color: #006000;
                -webkit-writing-mode: vertical-lr;
                -ms-writing-mode: vertical-lr;
                writing-mode: tb-lr;
            }
    
    
            .demo1 .div3 {
                height: 100px;
                width: 200px;
                margin: auto 0;
                background-color: red;
            }                
    html
    <div class="demo1">
        <div class="div3"></div>
    </div>

    3. 可以使用text-align:center实现图片垂直居中
    css
       
           .demo2 {
                -webkit-writing-mode: vertical-lr;
                -ms-writing-mode: vertical-lr;
                writing-mode: tb-lr;
                height: 300px;
                background-color: #006000;
                text-align: center;
            }                
    html
    <div class="demo2">
        <img src="images/1s.jpg">
    </div>

    4. 可以使用text-indent实现文字下沉效果
    css
    .demo3{
                -webkit-writing-mode: vertical-lr;
                -ms-writing-mode: vertical-lr;
                writing-mode: tb-lr;
            }
            .demo3 a {
                border: 10px solid red;
                text-decoration: none;
                -webkit-border-radius: 50%;
                -moz-border-radius: 50%;
                border-radius: 50%;
                text-align: center;
                font-size:28px;
                color: darkred;
                display: block;
                height:50px;
                width: 50px;
                line-height: 50px;
                background-color: red;
                box-shadow: inset 0 0 1px darkred, 0 1px, 0 2px, 0 4px;
            }
    
    

    html

    <div class="demo3">
        <a href="javascript:void(0)"></a>
    </div>
    5. 可以实现全兼容的icon fonts图标的旋转效果
    就是设置包含icon的父元素的writing-mode为vertical-rl,就可以实现元素的180度旋转

    writing-mode和direction的关系

    writing-modedirectionunicode-bidi是CSS世界中3大可以改变文本布局流向的属性。其中directionunicode-bidi属于近亲,经常在一起使用,也是唯一两个不受CSS3 all属性影响的CSS属性,基本上就是和内联元素一起使用使用。

    乍一看,writing-mode似乎包含了directionunicode-bidi某些功能和行为,例如vertical-rlrldirectionrtl值有相似之处,都是从右往左。然而,实际上,两者是没有交集的。因为vertical-rl此时的文档流为垂直方向,rl表示水平方向,此时再设置direction:rtl,实际上值rtl改变的是垂直方向的内联元素的文本方向,一横一纵,没有交集。而且writing-mode可以对块状元素产生影响,直接改变了CSS世界的纵横规则,要比direction强大和鬼畜的多。

    然而,CSS的奇妙就在于,某些特性当初可能就是问了某些图文排版设计,但是,我们可以利用其带来的特性,发挥自己的创造力,实现其他很多意想不到的效果。所以,上面出现的三剑客都是非常好的资源。

    writing-mode和*-start属性的流机制

    CSS3中出现了诸多*-start/*-end属性(亦称为CSS逻辑属性),例如:margin-start/margin-endborder-start/border-endpadding-start/padding-end, 以及text-align:start/text-align:end声明。

    下面问题来了,为什么会蹦出这么多*-start/*-end鬼?

    那是因为现代浏览器加强了对流的支持,包括老江湖direction,以及最近年月跟进的writing-mode

    在很久以前,我们的认知里,网页布局就一种流向,就是从左往右,从上往下,因此,我们使用margin-left/margin-right没有任何问题。但是,如果我们流是可以变化的,例如,一张图片距离左边缘20像素,我们希望其文档流是从右往左,同时距离右侧是20像素,怎么办?

    此时,margin-left:20px在图片direction变化后,就无效了;但是,margin-start就不会有此问题,所谓start, 指的是文档流开始的方向,换句话说,如果页面是默认的文档流,则margin-start等同于margin-left,如果是水平从右往左文档流,则margin-start等同于margin-rightmargin-end也是类似的。

    webkit内核的浏览器还支持*-before*-end,默认流下的margin-before近似于margin-topmargin-after近似于margin-bottom,然而,规范貌似没提及,FireFox也没支持,*-before*-after出场的机会并不多,为什么呢?因为实际上,配合writing-mode,*-start/*-end已经可以满足我们对逻辑位置的需求了,水平和垂直都可以控制,对立方向适用老的*-top/*-bottom.

    
    

    例如,我们设置writing-mode值为vertical-rl,此时margin-start等同于margin-top,如果此时margin-startmargin-top同时存在,会遵循权重和后来居上原则进行相互的覆盖。

    
    

    可以看到,场景不同,margin-start的作用也不能,能上能下,能左能右简直在世百变星君。

    
    

    关于*-start/*-end以后有机会会具体展开论述,这里就先点到为止,大家估计目前也不会在实际项目中使用。





    来自:http://www.zhangxinxu.com/wordpress/2016/04/css-writing-mode/

  • 相关阅读:
    去除图片水印
    CALayer
    UIKit Animation
    CoreAnimation
    3DTouch
    键盘事件
    weChat聊天发送图片带有小尖角的实现
    webView 和 js 交互 之 屏蔽 样式
    iOS socket编程
    tableView尾部多处一部分空白高度
  • 原文地址:https://www.cnblogs.com/xiaofenguo/p/6168865.html
Copyright © 2011-2022 走看看