Я знаю, что могу установить кнопку отправки внутри ввода, но я пытаюсь создать ее самостоятельно.
Желаемый результат:
Итак, розовая коробка — это div:
<div class = "numberSubmittion SimpleInputBox buttonCorners brandBlue" >
<input type = "number" class = "font" name = "productPrice" placeholder = "Enter Your Phone Number">
<button type = "submit" value = ">">
</div>
css:
.numberSubmittion {
height: 100%;
}
.numberSubmittion input {
height: 100%;
width:75%;
margin-left: 0px;
font-size: 14;
border:0px solid clear;
outline-width: 0;
border-width: 0px;
background-color: rgba(255, 0, 0, 0.1);
}
.numberSubmittion button {
height: 100%;
width:25%;
display: inline-block;
outline-width: 0;
border-width: 0px;
background-color: rgba(255, 0, 255, 0.1);
}
Итак, я правильно ввожу, как мне найти кнопку справа? Прямо сейчас кнопка находится за пределами розового div и находится слева.
РЕДАКТИРОВАТЬ
После исправления моего html для удаления пробелов:
<input type = "number" class = "font" name = "productPrice" placeholder = "Enter Your Phone Number"><button type = "submit" value = "ab">
но теперь, когда они выровнены, входной div имеет некоторое верхнее поле и не выровнен по вертикали с розовым, в то время как кнопка выровнена хорошо.
Пожалуйста, исправьте ошибки форматирования и включите остальные CSS.
@ ЭндрюL64 да. Пожалуйста, смотрите мое редактирование кода.






* {
box-sizing: border-box;
font-family: inherit;
margin: 0;
padding: 0;
}
html {
font-size: 62.25%;
}
body {
font-family: sans-serif;
font-size: 1.6rem;
}
.num-box {
margin: 5rem auto;
width: 300px;
display: flex;
background-color: pink;
border-radius: 1rem;
overflow: hidden;
justify-content: center;
align-items: center;
}
.num-input {
width: calc(100% - 40px);
padding: 2rem;
border: 0;
background: transparent;
font-family: sans-serif;
font-size: 2rem;
outline: none;
}
.num-btn {
width: 40px;
height: 40px;
padding: 10px;
position: relative;
border: 0;
outline: none;
background: transparent;
}
.num-btn::after {
position: absolute;
top: 50%;
left: 50%;
width: 30px;
height: 30px;
display: flex;
justify-content: center;
align-items: center;
content: '✔';
transform: translate(-50%, -50%);
background-color: #fff;
border-radius: 50%;
color: #9e9b9b;
cursor: pointer;
}<!DOCTYPE html>
<html lang = "en">
<head>
<meta charset = "UTF-8">
<title>Hello World From Gaurav</title>
</head>
<body>
<div class = "num-box">
<input type = "number" name = "" id = "" class = "num-input" placeholder = "Type number">
<button class = "num-btn"></button>
</div>
</body>
</html>Фиксированный.
у вас не может быть пробелов в html :
<input type = "number" class = "font" name = "productPrice" placeholder = "Enter Your Phone Number"><button type = "submit" value = "ab">
Затем при использовании inline-block вы должны выровнять оба элемента поверху vertical-align:top
Итак, вы хотите, чтобы «>» был внутри розового элемента
.numberSubmittion?