Is it possible to make a squiggly line?

前端 未结 12 1685
无人及你
无人及你 2021-02-01 19:04

If I wanted to make a horizontal line, I would do this:




        
12条回答
  •  礼貌的吻别
    2021-02-01 19:48

    This question is fairly old, but I found a way to do with without Javascript, repetitive CSS or images.

    With background-size you can repeat a pattern, which can be created with pure CSS using linear-gradient or radial-gradient.

    I put a bunch of examples here: http://jsbin.com/hotugu/edit?html,css,output

    example

    The basic gist is:

    .holder {
      /* Clip edges, as some of the lines don't terminate nicely. */
      overflow: hidden;
      position: relative;
      width: 200px;
      height: 50px;
    }
    
    .ellipse {
      position: absolute;
      background: radial-gradient(ellipse, transparent, transparent 7px, black 7px, black 10px, transparent 11px);
      background-size: 36px 40px;
      width: 200px;
      height: 20px;
    }
    
    .ellipse2 {
      top: 20px;
      left: 18px;
      background-position: 0px -20px;
    }

    You can produce some convincing squiggly lines with some modifications:

    .holder {
        position: relative;
        width: 200px;
        height: 50px;
        top: 25px;
    }
    .tinyLine {
        position: absolute;
        /* Cuts off the bottom half of the pattern */
        height: 20px;
        /* For better cross browser consistency, make it larger with width.  */
        width: 1000%;
        /* And then scale it back down with scale, recentering with translateX. */
        transform: translateX(-45%) scale(0.1);
    }
    
    .tinyLine1 {
        background: linear-gradient(45deg, transparent, transparent 49%, red 49%, transparent 51%);
    }
    .tinyLine2 {
        background: linear-gradient(-45deg, transparent, transparent 49%, red 49%, transparent 51%);
    }
    .tinyLine {
        /* Must be after background definition. */
        background-size: 40px 40px;
    }

    The browser support is okay (http://caniuse.com/#feat=css-gradients), IE 10 will probably work, however things break down at small scales in different browsers. If you want it to work on really small scales consistently you may want to make the line on a larger scale and then scale it down with transform: scale(x);.

    It should also be very fast, linear-gradients are rendered on the GPU in chrome.

提交回复
热议问题