zoukankan      html  css  js  c++  java
  • 字符圆角尖角实现对话框

    尽管现在很多浏览器都支持圆角border-radius这个属性了。

    以前做圆角还没那么简单的时候,能用其他方法模拟出圆角,但是不尽完美就是了。

    以前在看对话框的时候就疑惑,对话框旁边的小尖角是怎么做的。

    看到一篇博客用字符做出来,感觉又get到了技能。

    用字符做圆角的话,还是略显粗糙,在浏览器放大到150的时候就显现出来了。

    但是尖角的话用作对话的指向确实不错,浏览器兼容也可以。

    第二个对话框要实现字符边框效果,关键在于多做一个覆盖层,通过定位的差距遮挡住前一个圆角的绝大部分,只露出圆弧部分实现。

    点击看效果demo

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <link rel="styleSheet" href="./demo.css">
        <title>Document</title>
        <style>
            .ml20{
                margin: 0 auto;
                display: inline-block;
            }
            .sharp_square{
                 333px;
                height: 110px;
                background: #a0b3d6;
                position: relative;
                color: #a0b3d6;
            }
            .sharp_top_corner{
                line-height: 1;
                position: absolute;
                font-size: 34px;
                top: 32px;
                /* right: 80px; */
                left: -17px;
            }
            .sharp_square .quarter_round {
                position: absolute;
            }
            .quarter_round{
                display:inline-block; 
                8px; 
                height:8px; 
                overflow:hidden; 
                font-family:'宋体';
            }
            .quarter_round span{
                display:inline-block; 
                font-size:16px; 
                line-height:1;
            }
            .sharp_square .round_lt {
                left: -1px;
                top: -1px;
            }
            .sharp_square .round_rt {
                right: -1px;
                top: -1px;
            }
            .sharp_square .round_lb {
                left: -1px;
                bottom: 0px;
            }
            .sharp_square .round_rb {
                right: -1px;
                bottom: 0px;
            }
            .content_square{
                color: #fff;
                padding: 20px;
                font-size: 14px;
            }
            .sharp_square .quarter_round span {
                background: white;
            }
            .quarter_round .lt{}
            .quarter_round .rt{margin-left:-7px;}
            .quarter_round .lb{
                position: absolute;
                left: 0px;
                top: -6px;
            }
            .quarter_round .rb{
                position: absolute;
                /* left: 0px; */
                top: -5px;
                right: -1px;
            }
            .square_out_border {
                 472px;
                border: 1px solid #dadada;
                background: #f8f8f8;
                position: relative;
                color: #dadada;
            }
            .square_inner_border {
                border: 1px solid #ffffff;
                padding: 20px;
                font-size: 14px;
                color: #333333;
            }
            .square_top_corner{
                line-height: 1;
                height: 15px;
                font-size: 30px;
                position: absolute;
                top: -15.99px;
                right: 80px;
            }
            .square_top_corner2 {
                line-height: 1;
                font-size: 30px;
                color: #f8f8f8;
                position: absolute;
                top: 2px;
                right: 0;
            }
            .square_out_border .round_lt {
                left: -3px;
                top: -3px;
            }
           
            .square_out_border .quarter_round {
                position: absolute;
                z-index: 1;
            }
           
            .quarter_round {
                display: inline-block;
                 8px;
                height: 8px;
                overflow: hidden;
                font-family: '宋体';
            }
            .square_out_border .quarter_round span {
                background: #f8f8f8;
            }
            
            .quarter_round .lt {
            }
             
            .quarter_round span {
                display: inline-block;
                font-size: 16px;
                line-height: 1;
            }
            .square_out_border .round_lb {
                left: -3px;
                bottom: -1px;
            }
            .square_out_border .round_rb {
                right: -2px;
                bottom: -1px;
            }
            .square_out_border .round_rt {
                right: -2px;
                top: -4px;
            }
            .square_out_border .round_lt2 {
                left: -2px;
                top: -2px;
            }
             
            .square_out_border .quarter_round2 {
                color: #f8f8f8;
                z-index: 2;
            }
            .square_out_border .round_rt2 {
                right: -1px;
                top: -3px;
            }
             
            .square_out_border .quarter_round2 {
                color: #f8f8f8;
                z-index: 2;
            }
            .square_out_border .round_lb2 {
                left: -2px;
                bottom: 0px;
            }
            
            .square_out_border .quarter_round2 {
                color: #f8f8f8;
                z-index: 2;
            }
            .square_out_border .round_rb2 {
                right: -1px;
                bottom: 0px;
            }
            
            .square_out_border .quarter_round2 {
                color: #f8f8f8;
                z-index: 2;
            }
            .square_out_border .quarter_round2 span {
                background: none;
            }
            .method4{
                float: left;
            }
            .con1{
                float: left;
            }
            .method3{
                margin: 0 auto;
            }
            .method3 .zxx_ul_image{
                display: inline-block;
                margin-left: 100px;
            }
        </style>
    </head>
    <body>
        <div class="demo-container">
                <div class="header">
                        <i>
                            <b>字符圆角和尖角实现对话框</b>
                        </i>
                    </div>
            <div class="method-title">
                对话框
            </div>
            <div class="method-container">
                <div class="method4">
                    <ul class="zxx_ul_image">
                        <li>
                            <img src=".././images/monkey.jpg" />
                        </li>                    
                    </ul>
                </div>
                <div class="ml20 con1">
                    <div class="sharp_square mt20">
                        <span class="sharp_top_corner">◄</span>
                        <span class="quarter_round round_lt"><span class="lt">●</span></span>
                        <span class="quarter_round round_rt"><span class="rt">●</span></span>
                        <span class="quarter_round round_lb"><span class="lb">●</span></span>
                        <span class="quarter_round round_rb"><span class="rb">●</span></span>
                        <div class="content_square"><span>以四分之一实体圆填充四个角,添加尖角符,实现带尖角的实色圆角矩形。</span></div>
                    </div>
                </div>
                <br style="clear:both">
            </div>
            <div class="method-container">
                <div class="method3">
                    <ul class="zxx_ul_image">
                        <li>
                            <img src=".././images/insect.jpg" />
                        </li>
                    </ul>
                </div>
                <div class="ml20">
                    <div class="square_out_border mt20">
                        <span class="square_top_corner">◆
                            <span class="square_top_corner2">◆</span>
                        </span>
                        <span class="quarter_round round_lt">
                            <span class="lt">●</span>
                        </span>
                        <span class="quarter_round round_rt">
                            <span class="rt">●</span>
                        </span>
                        <span class="quarter_round round_lb">
                            <span class="lb">●</span>
                        </span>
                        <span class="quarter_round round_rb">
                            <span class="rb">●</span>
                        </span>
                        <div class="square_inner_border">
                            以四分之一实体圆填充四个角,重复一次,1像素错位。添加尖角符,2像素上下错位,矩形双层标签,实现最终的双边框效果。
                        </div>
                        <span class="quarter_round quarter_round2 round_lt2">
                            <span class="lt">●</span>
                        </span>
                        <span class="quarter_round quarter_round2 round_rt2">
                            <span class="rt">●</span>
                        </span>
                        <span class="quarter_round quarter_round2 round_lb2">
                            <span class="lb">●</span>
                        </span>
                        <span class="quarter_round quarter_round2 round_rb2">
                            <span class="rb">●</span>
                        </span>
                    </div>
                </div>
            </div>
        </div>
    </body>
    </html>
    

      google下效果图:

    ie11效果图

      

  • 相关阅读:
    2017.12.07 postgresql使用with recursive完成迭代查询
    jackson/fastJson boolean类型问题
    postgres sql merge upsert
    postgresql 清除数据并清除自增ID
    elasticsearch7.2深度分页实现(查询全部数据)
    SpringBoot集合SpringSecurity流程及代码详解和导图详解
    SpringBoot整合JWT框架及JWT介绍
    浅析JWT中token过期后解析报错ExpiredJwtException的解决及过期之后如何进行后续业务处理
    SpringSecurity整合JWT一些异常了解及处理io.jsonwebtoken.SignatureException: JWT signature does not match locally computed signature解决及UnsupportedJwtException:Signed Claims JWSs are not supported
    浅析request.getInputStream()得到的流及接参流程
  • 原文地址:https://www.cnblogs.com/lemon-zhang/p/8005236.html
Copyright © 2011-2022 走看看