怎么用 css3实现波浪底纹效果

html-css026

怎么用 css3实现波浪底纹效果,第1张

div{

    background:

    radial-gradient(circle at 100% 50%, transparent 20%, rgba(255,255,255,.3) 21%, rgba(255,255,255,.3) 34%, transparent 35%, transparent),

    radial-gradient(circle at 0% 50%, transparent 20%, rgba(255,255,255,.3) 21%, rgba(255,255,255,.3) 34%, transparent 35%, transparent) 0 -50px

    background-color: slategray

    background-size:75px 100px

}

更多背景底纹私聊我给你网址,有好多

波浪效果大部分是背景图片,不一定是border,也可以是下面有一个元素并且设定高度有背景平铺,还有就是用css3去写,如果border的圆角效果,可以去拼出一个,要不就是用vml去写,其实都没有第一种兼容效果好!!!!

搜了几篇老外的文章,提到 svg 的 forginObject 内的 HTML 元素,当应用 CSS3 动画时,动画的 transform-origin 是基于最外层 body 定位的,貌似无解。

个人建议使用 svg 的 SMIL 动画来实现波纹特效,你大屏展示用的话,兼容性啥的应该不是主要问题。写了简单示例代码:

<!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">

    <title>svg 动画示例</title>

    <style>

    html,

    body,

    svg {

        width: 100%

        height: 100%

    }

    body {

        padding: 0

        margin: 0

        background: #232323

    }

    .eanimation {

        stroke: rgb(181, 255, 255)

        box-shadow: inset 0px 0px 8px rgba(29, 146, 226, 0.75)

    }

    </style>

</head>

<body>

    <svg xmlns="http://www.w3.org/2000/svg">

        <g>

            <g>

                <circle class="eanimation" cx="200" cy="200" r="96" stroke-width="3" fill="transparent"/>

                <animateTransform

                 attributeName="transform"

                 type="scale"

                 dur="1s"

                 values="0.51"

                 repeatCount="indefinite"/>

            </g>

            <g>

                <circle class="eanimation" cx="200" cy="200" r="96" stroke-width="3" fill="transparent"/>

                <animateTransform

                    attributeName="transform"

                    type="scale"

                    dur="1s"

                    values="0.651"

                    additive="sum"

                    repeatCount="indefinite"/>

            </g>

            <animate attributeName="opacity" begin="0s" dur="1s" from="1" to="0" repeatCount="indefinite"/>

        </g>

    </svg>

</body>

</html>