• CSS3 clip-path & clip-path 打破矩形设计的限制


    CSS 形状模块标准1(CSS Shapes Module Level 1)这个规范打破了 WEB 中的矩形盒模型的限制,并且将网页设计提升到一个新的高度。

    关于 Shapes 规范 shape-outside

    shape-outside CSS 属性可以来设置行内内容应该包裹的形状,默认形状为:margin-box。这一属性足以让我们发挥各种想象,从此我们的元素设计将不会仅仅存在于一个矩形内,它可以是任何形状。

    • shape-outside: none :没有形状就是默认形状:margin-box
    • shape-outside: margin-box :定义一个由外边距的外边缘封闭形成的形状。
    • shape-outside: border-box :定义一个由边界的外边缘封闭形成的形状。
    • shape-outside: padding-box :定义一个由内边距的外边缘封闭形成的形状。
    • shape-outside: content-box :定义一个由内容区域的外边缘封闭形成的形状

    以上属性定义了整个区域的范围,其实和 box-sizing 比较类似。

    • shape-outside: circle() :定义一个圆形函数来绘制包裹形状。
    • shape-outside: ellipse() :定义一个椭圆形函数来绘制包裹形状。
    • shape-outside: inset()
    • shape-outside: polygon() :定义一个多边形函数来绘制包裹形状。

    以上属性是来绘制整个包裹区域的形状的,有点类似于 SVG 或者 Canvas 的绘制图像函数。

    • shape-outside: url() :定义区域内背景图。
    • shape-outside: linear-gradient() :定义区域内背景渐变色。

    以上属性是来给整个区域设置背景的。

    剪裁 clip-path

    clip-path CSS 属性可以用来设置一个元素的剪切区域,区域内的部分显示,区域外的部分隐藏。

    • clip-path: none
    • clip-path: fill-box
    • clip-path: border-box
    • clip-path: padding-box
    • clip-path: content-box

    它们和 shape-outside 的区域范围定义比较类似。

    • clip-path: circle()
    • clip-path: ellipse()
    • clip-path: inset()

    它们和 shape-outside 的绘制形状比较类似。

    开始尝试

    有了 shape-outsideclip-path 我们不仅可以让行内元素产生不同的形状(影响周边元素),而且可以让块级元素剪切成自己想要的形状。

    以下 Demo 可以在这里修改查看:https://codepen.io/anon/pen/oMBwVK

    <!DOCTYPE html>
    <html>
    <head>
    <style>
        .circle-words {
            shape-outside: content-box circle();
            width: 200px;
            height: 200px;
            border-radius: 50%;
            background-color: #FF5A5F;
            float: left;
        }
        .circle-clip {
            background-color: #FF5A5F;
            width: 400px;
            height: 200px;
            clip-path: inset(15% 0 15% 0 round 0 15% 0 15%);
            margin: 30px;
            background-image: url(https://metaimg.baichanghui.com/METADATA/79d9a111-a39b-4904-b7e3-94068927d822);
        }
    </style>
    </head>
    <body>
        <div style=" 600px; margin: auto">
            <div class="circle-words"></div>
            Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World! Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World! Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World! Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!
            Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World! Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World! Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World! Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!Hello World!
        </div>
        <div style=" 600px; height: 600px; margin: auto; background-color: #999">
            <div class="circle-clip">
    
            </div>
        </div>
    </body>
    </html>


    作者:一俢
    链接:https://www.jianshu.com/p/bb3b2e97bd61

  • 相关阅读:
    expect详解及自动登录脚本的实现
    NFS服务端+客户端配置
    交互式shell脚本对话框----whiptail指令
    自定制Centos7.3系统镜像(ISO)
    云原生简述
    Linux下修改MTU(最大传输单元)
    MySQL-5.7组提交(Group Commit)原理
    AWS putty终端ssh密钥登陆方法
    一个简单的从web页面获取数据插入数据库的小程序
    新建一个简单的Java web前后台交互小程序时报错:java.lang.ClassNotFoundException: com.microsoft.sqlserver.jdbc.SqlServerDriver
  • 原文地址:https://www.cnblogs.com/cangqinglang/p/11384772.html
Copyright © 2020-2023  润新知