如何创建此按钮样式?

时间:2017-06-15 08:39:54

标签: css css3 svg

我需要在下面的图像中创建按钮样式(右侧的按钮样式是透明的,而不是白色)。

右下角显然是棘手的部分。它不仅仅是一个简单的斜面;它有点圆润。

我提出的最佳解决方案是将SVG图像蒙版应用于位于按钮右侧的伪元素,并减少右边距以进行补偿。但这种方法有其局限性:

  • 它需要一个固定的高度按钮(至少,如果我想保持角落的纵横比)
  • 每个按钮大小需要不同的SVG
  • 我不知道它如何适用于透明按钮样式

所以我希望有人能提出不同/更好的方法!

由于

更新

以下是我目前的做法 - https://codepen.io/peteheaney/pen/jwVEPm

$primary: #FAB500;

*, *::after, *::before {
    font-family: sans-serif;
    box-sizing: border-box;
}

.button {    
  background-image: none;
  border-width: 2px;
  border-style: solid;
  border-color: transparent;
  cursor: pointer;
  display: inline-block;
  font-weight: bold;
  margin-bottom: 0;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  touch-action: manipulation;
  vertical-align: middle;
  white-space: nowrap;
  transition: all 0.2s;

  &:active,
  &:hover,
  &:focus {
    text-decoration:none;
  }

  &--large {
    font-size: 15px;
    padding-left: 24.818px;
    height: 52px;
    line-height: 52px;
    border-top-left-radius: 6px;
    border-bottom-left-radius: 6px;
    position: relative;
    margin-right: 24.818px;

    &:after {
            border-top: 2px solid $primary;
            border-bottom: 2px solid $primary;
            background: $primary;
      content: "";
      border-top-right-radius: 6px;
      position: absolute;
      left: 100%;
      bottom: -2px;
      width: 24.818px;
      height: 52px;
      mask: url(http://assets.peteheaney.com.s3.amazonaws.com/button-corner-right.svg) top left / cover;
    }
  }

    &--primary {
        color: #000;
        background-color: $primary;
        border-color: $primary;

        &:active,
        &:hover,
        &:focus {
            background-color: darken($primary, 2%);
            border-color: darken($primary, 2%);
        }
    }
}

enter image description here

6 个答案:

答案 0 :(得分:0)

如果你不介意让角落可以点击,你可以让按钮不可见,只使用背景图片:

button{
    width:x;
    height:y;
    border:none;
    background-color:none
    background-image:url(button_image.png);
    background-position:center;
    background-size:x y;
    background-repeat:no-repeat;
}

使用button_image.png作为没有文字的按钮样式的图像。

答案 1 :(得分:0)

您可以尝试使用beforeafter

这样绘制

.button {
  position: relative;
  display: inline-block;
  background-color: orange;
  color: white;
  padding: 20px 40px;
  font-size: 14px;
  border-radius: 5px;
  text-decoration: none;
}

.button:after {
  content: '';
  position: absolute;
  z-index: 10;
  display: block;
  bottom: -6px;
  right: -2px;
  width: 10px;
  height: 20px;
  transform: rotate(45deg);
  background-color: white;
}

.button:before {
  content: '';
  position: absolute;
  z-index: 100;
  display: block;
  bottom: -1px;
  right: 4px;
  width: 13px;
  height: 23px;
  transform: rotate(45deg);
  background-color: orange;
  border-radius: 10px;
}
<a href="#" class="button">Button</a>

答案 2 :(得分:0)

以下是使用纯CSS实现这一目标的示例。 但是,图像或SVG可能是解决此问题的更有效方法。

&#13;
&#13;
.Large{
  position:relative;
  display:inline-block;
  background:#FFB300;
  border:none;
  padding:20px 0 20px 30px;
  border-radius:10px 0 0 10px;
  height:40px;
  font:700 1.5em/40px Arial;
}
.Large::after{
  content:"";
  display:block;
  position:absolute;
  top:0;
  right:-30px;
  width:30px;
  height:50px;
  background:#FFB300;
  border-radius:0 10px 0 0;
}
.Large::before{
  content:"";
  display:block;
  position:absolute;
  bottom:0;
  right:-30px;
  width:0;
  height:0;
  border-top: 15px solid #FFB300; 
  border-right: 15px solid transparent;
  border-bottom: 15px solid transparent;  
  border-left: 15px solid #FFB300;
}
&#13;
<a class="Large">LARGE</a>
&#13;
&#13;
&#13;

答案 3 :(得分:0)

我对自己的结果并不满意,但是这样可以防止你做得更好。

不同的颜色只是为了让它更容易看出是什么。

我专注于解决透明的问题。一旦你拥有它,解决另一个更容易。

&#13;
&#13;
X
&#13;
:root {
  --width: 10px;
  --width2: 14px;
}


.test {
  position: relative;
  margin: 20px;
  width: 300px;
  height: 150px;
  position: absolute;
  border: var(--width) solid transparent;
  border-image: linear-gradient(to bottom right, orange 0%, orange 70%, transparent 70%);
  border-image-slice: 1;
}

.test:before {
  content: "";
  position: absolute;
  height: 25px;
  width: 150px;
  right: 29px;
  bottom: -10px;
  transform: skewX(-45deg);
  border: solid 0px transparent;
  border-bottom-color: red;
  border-bottom-width: var(--width);
  border-right-color: red;
  border-right-width: var(--width2);
  border-bottom-right-radius: 25px;
}


.test:after {
  content: "";
  position: absolute;
  height: 50px;
  width: 25px;
  right: -10px;
  bottom: 29px;
  transform: skewY(-45deg);
  border: solid 0px transparent;
  border-bottom-color: red;
  border-bottom-width: var(--width2);
  border-right-color: red;
  border-right-width: var(--width);
  border-bottom-right-radius: 25px;
}
&#13;
&#13;
&#13;

答案 4 :(得分:0)

我决定采用我在此笔中演示的方法 - https://codepen.io/peteheaney/pen/bRBOMq(下面编译的CSS版本)

*, *::after, *::before {
  font-family: sans-serif;
  box-sizing: border-box;
}

.button {
  background-image: none;
  border-style: solid;
  border-top-width: 2px;
  border-bottom-width: 2px;
  border-left-width: 2px;
  border-right-width: 0;
  border-color: transparent;
  cursor: pointer;
  display: inline-block;
  font-weight: bold;
  margin-bottom: 0;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  touch-action: manipulation;
  vertical-align: middle;
  white-space: normal;
  transition: all 0.2s;
}
.button:active, .button:hover, .button:focus {
  text-decoration: none;
}
.button--large {
  font-size: 15px;
  padding: 16px 0 14px 21px;
  border-top-left-radius: 6px;
  border-bottom-left-radius: 6px;
  position: relative;
  margin-right: 21px;
}
.button--large:before {
  content: "";
  position: absolute;
  left: 100%;
  top: -2px;
  width: 21px;
  height: calc(100% - 17px);
  border-top-right-radius: 6px;
}
.button--large:after {
  position: absolute;
  left: 100%;
  bottom: -2px;
  width: 21px;
  height: 21px;
  transition: all 0.2s;
}
.button--primary {
  color: #000;
  background-color: #FAB500;
  border-color: #FAB500;
}
.button--primary:before {
  background-color: #FAB500;
  transition: all 0.2s;
}
.button--primary:active:before, .button--primary:hover:before, .button--primary:focus:before {
  background-color: #f0ae00;
  border-color: #f0ae00;
}
.button--primary:after {
  content: url(http://assets.peteheaney.com.s3.amazonaws.com/button-corner-primary-large.svg);
}
.button--primary:active, .button--primary:hover, .button--primary:focus {
  background-color: #f0ae00;
  border-color: #f0ae00;
}
.button--secondary {
  color: #000;
  border-color: #FAB500;
}
.button--secondary:before {
  border: 2px solid #FAB500;
  border-bottom: 0;
  border-left: 0;
  transition: all 0.2s;
}
.button--secondary:active:before, .button--secondary:hover:before, .button--secondary:focus:before {
  background-color: #FAB500;
}
.button--secondary:after {
  content: url(http://assets.peteheaney.com.s3.amazonaws.com/button-corner-secondary-large.svg);
}
.button--secondary:active, .button--secondary:hover, .button--secondary:focus {
  background-color: #FAB500;
  border-color: #FAB500;
}
<a class="button button--large button--primary" href="">My button</a>

<a class="button button--large button--secondary" href="">My other button</a>

首先,我将右手部分分为顶部和底部(使用:之前和之后)。右上角的伪元素只有背景颜色和右上边框半径。这样,右上部分可以具有柔性高度,这意味着按钮不需要具有固定高度。右下角的伪元素本质上是一个SVG(使用内容:url(/path/to/svg.svg))。此伪元素始终具有固定的宽度和高度,因此无论按钮的宽度/高度如何,它都会保持其大小和宽高比。

大纲样式按钮只是其他样式的变体,具有更多边框和更少背景。

这种方法的唯一缺点是每种按钮样式需要不同的SVG。但我很满意这种妥协。

答案 5 :(得分:0)

另一种对亚瑟方法的看法。

如果您创建了右下方的图像(白色角落和黄色角落边框),您可以将其定位,使其保持在右下方,您可以使用按钮的其余部分来自行调整样式。

 button {
    background-image:url(corner.svg);
    height: 20px;
    padding: 5px;
    border-radius: 5px;
    background-color: yellow;
    background-repeat: no-repeat;
    background-position: bottom right;
}