自定义旋转框箭头

时间:2019-12-18 18:00:01

标签: html css

我想知道如何自定义旋转框的箭头。

input[type="number"]::-webkit-inner-spin-button, 
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: inner-spin-button !important;
    opacity: 1 !important;
}
<input type="number" />

这就是我想要的。

This is what I want to get.

我应该从哪里开始? (我必须使用jQuery小部件还是JavaScript对其进行自定义?)

2 个答案:

答案 0 :(得分:3)

屏幕截图(Chrome,macOS):

enter image description here

代码:

input[type="number"] {
  height: 32px;
  border-radius: 4px;
  border: 1px solid #d8d8d8;
  position: relative;
  text-align: center;
  font-size: 20px;
  width: 80px;
  outline: none;
  background-image: url('data:image/svg+xml;utf8,%3Csvg%20version%3D%221.1%22%20viewBox%3D%220%200%2050%2067%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%20stroke-width%3D%222%22%3E%3Cline%20x1%3D%221%22%20x2%3D%2250%22%20y1%3D%2233.5%22%20y2%3D%2233.5%22%20stroke%3D%22%23D8D8D8%22%2F%3E%3Cpolyline%20transform%3D%22translate(25%2020)%20rotate(45)%20translate(-25%20-20)%22%20points%3D%2219%2026%2019%2014%2032%2014%22%20stroke%3D%22%23000%22%2F%3E%3Cpolyline%20transform%3D%22translate(25%2045)%20rotate(225)%20translate(-25%20-45)%22%20points%3D%2219%2052%2019%2039%2032%2039%22%20stroke%3D%22%23000%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E');
  background-position: center right;
  background-size: contain;
  background-repeat: no-repeat;
  caret-color: transparent;
}

input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  opacity: 1 !important;
  background: transparent !important;
  border-width: 0px;
  margin: 0;
  border-left: 1px solid #d8d8d8;
  height: 34px;
  width: 23px;
  cursor: pointer;
}
<input type="number" value="1" />

所以,可以做到。但是,这样的自定义通常非常脆弱(即使您添加了必要的跨浏览器属性,而我尚未完成;这仅在webkit中起作用),并且可能会损害可用性。您最好使用平台的本机控件。

答案 1 :(得分:1)

我的答案尝试使用css pure解决您的问题,例如,使用input[type=number] {}可以放置所有规则来更改输入的外观

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: inner-spin-button !important;
  opacity: 1 !important;
  width: 50px;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  background-color: blue !important;
  border: 2.5px solid red !important;
}

input[type=number] {
  position: relative;
  padding: 5px;
  width: 50px;
  padding-right: 25px;
  height: 30px;
  text-align: center;
  font-family: sans-serif;
  font-size: 2rem;
  border: 1px solid #9c9c9c !important;
  border-radius: 0.2em;
}
<input type="number" />

相关问题