在刚开始没有给输入框添加焦点之前,没有任何效果。见下图:
然后点击其中任何一个,焦点就会触发一个动画,动画的结果见图二:
中间的输入登录密码文字,会自动添加到顶部(原谅我没有截取到动画过程的图片)。
我测试了一下,这样的效果只有高级浏览器支持(IE只有IE10、IE11、Edge支持)。
下面我来把代码贴上来,原理很简单,就是通过事件触发类名的增加和删除。具体的动画由CSS3来实现,这也是为什么低级浏览器不支持的原因。
原生JS实现示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
*{
padding: 0;
margin: 0;
}
.demo{
border: 1px solid gray;
width: 300px;
height: 200px;
position: relative;
left: 200px;
top: 200px;
-webkit-transition: all 0.3s linear;
-moz-transition: all 0.3s linear;
-ms-transition: all 0.3s linear;
-o-transition: all 0.3s linear;
transition: all 0.3s linear;
}
.demo input{
width: 200px;
height: 100px;
position: absolute;
left: 50px;
top: 50px;
-webkit-transition: all 0.3s linear;
-moz-transition: all 0.3s linear;
-ms-transition: all 0.3s linear;
-o-transition: all 0.3s linear;
transition: all 0.3s linear;
}
.demo label{
position: absolute;
top: 100px;
left:80px;
font-size: 14px;
-webkit-transition: all 0.3s linear;
-moz-transition: all 0.3s linear;
-ms-transition: all 0.3s linear;
-o-transition: all 0.3s linear;
transition: all 0.3s linear;
}
.activeDemo{
border: 1px #fd715a solid;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-ms-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all 0.3s ease;
}
.activeInput{
border: 1px #fd715a solid;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-ms-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all 0.3s ease;
}
.activeLabel{
font-size: 10px;
color: #fd715a;
background: white;
-webkit-transform: translate(-20px, -58px);
-moz-transform: translate(-20px, -58px);
-ms-transform: translate(-20px, -58px);
-o-transform: translate(-20px, -58px);
transform: translate(-20px, -58px);
-webkit-transition: all 0.3s linear;
-moz-transition: all 0.3s linear;
-ms-transition: all 0.3 linear;
-o-transition: all 0.3s linear;
transition: all 0.3s linear;
}
</style>
</head>
<body>
<div class="demo">
<input type="text" id="inputDemo"/>
<label for="inputDemo">请输入内容</label>
</div>
</body>
<script>
var addEvent= function (obj,event,callback) {
if(obj.addEventListener){
obj.addEventListener(event,callback)
}else if(obj.attachEvent){
obj.attachEvent('on'+event,callback)
}
};
var demo=document.querySelector(".demo");
var input=document.querySelector("#inputDemo");
var label=document.querySelector(".demo label");
addEvent(input,"focus", function () {
demo.className+=" activeDemo";
this.className+=" activeInput";
label.className+=" activeLabel";
});
addEvent(input,'blur', function () {
this.className=this.className.replace(/\s*activeInput\s*/,' ');
label.className=label.className.replace(/\s*activeLabel\s*/,' ');
demo.className=demo.className.replace(/\s*activeDemo\s*/,' ');
})
</script>
</html>
下面是用Angular实现的一个简单的效果,原理很简单,就是在指令中通操作DOM来实现动画。
Angularjs实现示例:
<!DOCTYPE html> <html lang="en" ng-app="formAnimation"> <head> <meta charset="UTF-8"> <title></title> <script src="/UploadFiles/2021-04-02/angular.min.js">总结
上面的两种方式只是体现了一下实现的方式,具体的实现样式大家可以可以参照效果图,调节CSS样式。希望这篇文章的内容对大家学习Angularjs和JS能有所帮助,如果有问题可以留言交流,谢谢大家对的支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“利用Angularjs和原生JS分别实现动态效果的输入框”评论...
更新动态
2025年10月24日
2025年10月24日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]

