she*_*n96 8 html css forms material-design bootstrap-4
我想使用 css 和 bootstrap 设计以下材料设计输入表单。以下代码是我目前正在使用的。但它没有提供我想要的确切结果。
代码笔链接:在此处查看源代码
HTML代码:
<div class="container">
<h2>Google Material Design in CSS3<small>Inputs</small></h2>
<form>
<div class="group">
<input type="text" required>
<span class="highlight"></span>
<span class="bar"></span>
<label>Name</label>
</div>
<div class="group">
<input type="text" required>
<span class="highlight"></span>
<span class="bar"></span>
<label>Email</label>
</div>
</form>
<p class="footer">
a <a href="https://scotch.io/tutorials/css/google-material-design-input-boxes-in-css3" target="_blank">tutorial</a> by <a href="https://scotch.io" target="_blank">scotch.io</a>
</p>
</div>
Run Code Online (Sandbox Code Playgroud)
但我想要这样的设计:
Jer*_*bio 18
仅 CSS 解决方案;使用~标签上的兄弟选择器和:valid输入上的伪选择器的组合。
body {
margin: 10px;
}
.form-group>label {
bottom: 34px;
left: 15px;
position: relative;
background-color: white;
padding: 0px 5px 0px 5px;
font-size: 1.1em;
transition: 0.2s;
pointer-events: none;
}
.form-control:focus~label {
bottom: 55px;
}
.form-control:valid~label {
bottom: 55px;
}Run Code Online (Sandbox Code Playgroud)
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css">
<div class="container">
<div class="row">
<div class="col-md-6">
<br>
<div class="form-group">
<input type="text" class="form-control" id="usr" required>
<label for="usr">Name</label>
</div>
<div class="form-group">
<input type="text" class="form-control" id="password" required>
<label for="usr">Password</label>
</div>
</div>
</div>
</div>Run Code Online (Sandbox Code Playgroud)
由于您已经标记了 Bootstrap 4,我假设您想要有关该框架的解决方案。
像这样设置默认的表单组、标签和输入标记;
<div class="form-group">
<label for="usr">Name:</label>
<input type="text" class="form-control" id="usr">
</div>
Run Code Online (Sandbox Code Playgroud)
然后添加这个css,这会做的是
.form-group > label {
top: 18px;
left: 6px;
position: relative;
background-color: white;
padding: 0px 5px 0px 5px;
font-size: 0.9em;
}
Run Code Online (Sandbox Code Playgroud)
这是引导程序 4 上的代码的小提琴; http://jsfiddle.net/rw29jot4/
对于动画,检查这个小提琴,我们需要利用点击事件并移动标签的位置;
用动画更新代码; http://jsfiddle.net/sedvo037/