Issue
I'm trying to change the bottom border color when input type number is focused. In part I succeeded, but the css is not applied to all selectors. Here's the problem:
The left side (peso) is not focused, yet it has the same selector as Kg. Here is the code: https://jsfiddle.net/snake93/nLdrcv71/1/
input[type=number] {
color: #666;
border-width: 0px 0px 1px 0px !important;
border-color: #dcdcdc !important;
border-radius: 0px !important;
background: #fafafa00;
}
.input-group-text {
display: -ms-flexbox;
display: flex;
-ms-flex-align: center;
align-items: center;
padding: .375rem .75rem;
margin-bottom: 0px;
font-size: 1rem;
font-weight: 400;
line-height: 1.5;
color: #495057;
background-color: #ffffff00 !important;
border: 1px solid #dcdcdc !important;
border-radius: .25rem;
border-width: 0px 0px 1px 0px !important;
border-radius: 0px !important;
}
.form-control:focus,
.form-control:focus + span {
color: #00a1ff;
background-color: #fff0;
border-color: #00a1ff !important;
outline: 0;
box-shadow: none !important;
border: solid;
border-width: 0px 0px 2px 0px !important;
}
.input-group-text:focus {
background:red !important;
}
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.1/dist/css/bootstrap.min.css" rel="stylesheet">
<script src="https://cdn.jsdelivr.net/npm/@popperjs/core@2.9.3/dist/umd/popper.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.1/dist/js/bootstrap.min.js" ></script>
<div class="input-group mb-3">
<span class="input-group-text">Peso</span>
<input type="number" class="form-control">
<span class="input-group-text">Kg</span>
</div>
Solution
The selector .form-control:focus + span
only affects span that come after elements with the .form-control
class. Instead of this, you can use .input-group:focus-within span
which will apply your styling to children span when elements with the .input-group
class are focused.
.form-control:focus,
.input-group:focus-within span {
color: #00a1ff;
background-color: #fff0;
...
Edit: I have added the full markup to demonstrate that this solution does work.
input[type=number] {
color: #666;
border-width: 0px 0px 1px 0px !important;
border-color: #dcdcdc !important;
border-radius: 0px !important;
background: #fafafa00;
}
.input-group-text {
display: -ms-flexbox;
display: flex;
-ms-flex-align: center;
align-items: center;
padding: .375rem .75rem;
margin-bottom: 0px;
font-size: 1rem;
font-weight: 400;
line-height: 1.5;
color: #495057;
background-color: #ffffff00 !important;
border: 1px solid #dcdcdc !important;
border-radius: .25rem;
border-width: 0px 0px 1px 0px !important;
border-radius: 0px !important;
}
.form-control:focus,
.input-group:focus-within span {
color: #00a1ff;
background-color: #fff0;
border-color: #00a1ff !important;
outline: 0;
box-shadow: none !important;
border: solid;
border-width: 0px 0px 2px 0px !important;
}
.input-group-text:focus {
background:red !important;
}
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.1/dist/css/bootstrap.min.css" rel="stylesheet">
<script src="https://cdn.jsdelivr.net/npm/@popperjs/core@2.9.3/dist/umd/popper.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.1/dist/js/bootstrap.min.js" ></script>
<div class="input-group mb-3">
<span class="input-group-text">Peso</span>
<input type="number" class="form-control">
<span class="input-group-text">Kg</span>
</div>
Answered By - George Sun
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.