PlaceHolder in the margin of the input

4

What is the name of this effect or property? Is it from Bootstrap?:

As you can see, the placeHolder is aligned with the margin of the TextBox when you click inside it to write.

    
asked by afar1793 18.09.2017 в 23:48
source

1 answer

14

They are known as 'Floating labels / placeholders'. And they are based on Material Design . It is a type of design with certain standards created by Google.

There are several ways to do it and that varies from developer to developer, I leave you one way. You just need to put your own styles.

body{
 padding:50px;
} 
input[type="text"][required]:focus + label[placeholder]:before,
input[type="tel"][required]:focus + label[placeholder]:before,
input[type="password"][required]:focus + label[placeholder]:before,
input[type="email"][required]:focus + label[placeholder]:before,
form select[required]:focus + label[placeholder]:before
{
  color: #3399CC;
}

input[type="text"][required]:focus + label[placeholder]:before,
input[type="text"][required]:valid + label[placeholder]:before,
input[type="tel"][required]:focus + label[placeholder]:before,
input[type="tel"][required]:valid + label[placeholder]:before,
input[type="email"][required]:focus + label[placeholder]:before,
input[type="email"][required]:valid + label[placeholder]:before,
input[type="password"][required]:focus + label[placeholder]:before,
input[type="password"][required]:valid + label[placeholder]:before,
form select[required]:focus + label[placeholder]:before,
form select[required]:valid + label[placeholder]:before
{
  -webkit-transition-duration: .2s;
  transition-duration: .2s;
  -webkit-transform: translate(0, -0.8em) scale(0.9, 0.9);
  transform: translate(0, -0.8em) scale(0.9, 0.9);
}
input[type="text"][required]:invalid + label[placeholder][alt]:before,
input[type="tel"][required]:invalid + label[placeholder][alt]:before,
input[type="password"][required]:invalid + label[placeholder][alt]:before,
input[type="email"][required]:invalid + label[placeholder][alt]:before,
form select[required]:invalid + label[placeholder][alt]:before
{
  content: attr(alt);
}
input[type="text"][required] + label[placeholder],
input[type="tel"][required] + label[placeholder],
input[type="password"][required] + label[placeholder],
input[type="email"][required] + label[placeholder],
form select[required] + label[placeholder] 
{
  display: block;
  pointer-events: none;
  line-height: 1.25em;
  margin-top: calc(-1.5em - 2px);
  margin-bottom: calc((3em - 1em) + 2px);
  font-size: 0.85em;
  font-weight: normal;
}


input[type="text"][required] + label[placeholder]:before,
input[type="password"][required] + label[placeholder]:before,
input[type="tel"][required] + label[placeholder]:before,
input[type="email"][required] + label[placeholder]:before,
form select[required] + label[placeholder]:before
{
  content: attr(placeholder);
  display: inline-block;
  margin: 2px;
  padding: 0 6px;
  color: #9C9C9C;
  white-space: nowrap;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  background-image: -webkit-linear-gradient(top, #fff, #fff);
  background-image: linear-gradient(to bottom, #fff, #fff);
  background-size: 100% 5px;
  background-repeat: no-repeat;
  background-position: center;
}
<div class="form-group">
  <input type="password" class="form-control" required>
  <label placeholder="Ingresar NIP" for=""></label>
</div>
    
answered by 19.09.2017 в 00:00