Web前端——登录界面hover效果

本文展示了如何使用HTML、CSS和JavaScript创建一个登录页面,当鼠标悬停在输入框上时,会产生一个动态的效果。通过监听鼠标的enter和leave事件,动态生成并调整元素位置,实现视觉上的交互体验。代码包括HTML结构、CSS样式和JavaScript事件处理,详细解释了每个部分的作用。
摘要由CSDN通过智能技术生成

Demo1(来源:B站“艾恩小灰灰”)

源代码:

html+javascript:
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>用户登录</title>
    <link rel="stylesheet" href="../css/1.css">
    <script src="../js/jquery-3.6.0.min.js"></script>
</head>
<body>
    <div class="container">
        <h1>douyin</h1>
        <form action="">
            <input type="text" class="tbx" placeholder="账号">
            <input type="password" class="tbx" placeholder="密码">
            <input type="submit" class="sub" value="登录">
        </form>
    </div>
    <script>
        //定义一个con绑定.container
        const con=document.querySelector('.container');
        //定义两个函数开关(门)
        let isIn=true;  //鼠标进去的门,默认打开
        let isOut=false;  //鼠标出去的门,默认关闭
        var span;  //给未出生的元素取个名字span
        //添加监听
        //监听鼠标进去的事件
        con.addEventListener('mouseenter',(e)=>{
            //如果进去的门是打开的,就可以执行这个函数
            if(isIn){
                //获取进入的鼠标位置
                //生成元素的位置=进入点距离窗口的距离-父盒子距离窗口的距离
                let inX=e.clientX-e.target.offsetLeft;
                let inY=e.clientY-e.target.offsetTop;
                //创建一个span元素,并且给它对应的出生坐标
                let el=document.createElement('span');
                el.style.left=inX+'px';
                el.style.top=inY+'px';
                //添加到con对应的父元素,即container
                con.appendChild(el);
                $('.container span').removeClass('out');  //移除出去的动画
                $('.container span').addClass('in');  //添加进入的动画
                span=document.querySelector('.container span');
                isIn=false;  //关闭进来的门(不能使用进入的方法)
                isOut=true;  //打开出去的门(可以使用出去的方法)
            }
        })
        //监听鼠标出去的事件
        con.addEventListener('mouseleave',(e)=>{
            if(isOut){
                //获取出去的鼠标位置
                //生成元素的位置=出去点距离窗口的距离-父盒子距离窗口的距离
                let outX=e.clientX-e.target.offsetLeft;
                let outY=e.clientY-e.target.offsetTop;
                $('.container span').removeClass('in');  //移除进入的动画
                $('.container span').addClass('out');  //添加出去的动画
                //添加出去的坐标
                $('.out').css('left',outx+'px');
                $('.out').css('top',outx+'px');
                isOut=false;  //关闭出去的门
                //当动画结束后再删除元素
                setTimeout(() => {
                    con.removeChild(span);  //删除元素
                    isIn=true;  //打开进入的门
                },500);
            }
        })
    </script>
</body>
</html>
css:
*{
    margin: 0;
    padding: 0;
}
body{
    /*设置body高度为100%窗口高度*/
    height: 100vh;
    /*弹性盒子模型*/
    display: flex;
    /*限免两个属性是让body里的子类居中*/
    justify-content: center;
    align-items: center;
    background-color: #1d1928;
}
.container{
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: 350px;
    height: 450px;
    border-radius: 20px;
    background-color: #4471a3;
    /*盒子阴影*/
    box-shadow: 15px 15px 10px rgba(33,45,58,0.3);
    overflow: hidden;
    position: relative;
}
.container form{
    width: 350px;
    height: 200px;
    display: flex;
    justify-content: space-around;
    flex-direction: column;
    align-items: center;
    z-index: 1;
}
.container form .tbx{
    width: 250px;
    height: 40px;
    outline: none;
    border: none;
    border-bottom: 1px solid #fff;
    background: none;
    color: #fff;
    font-size: 15px;
}
/* 设置文本框提示文本的样式*/
.container form .tbx::placeholder{
    color: #fff;
    font-size: 15px;
}
.container form .sub{
    width: 250px;
    height: 40px;
    outline: none;
    border: 1px solid #fff;
    border-radius: 20px;
    letter-spacing: 5px;
    color: #fff;
    background: none;
    cursor: pointer;
    margin-top: 20px;
}
.container h1{
    color: #ecf0f1;
    font-size: 50px;
    letter-spacing: 5px;
    font-weight: 100;
    /*文字阴影*/
    text-shadow: 5px 5px 5px rgba(33,45,58,0.3);
    z-index: 1;
}
/*设置鼠标进入的样式*/
.container .in{
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: #cf455f;
    transform: translate(-50%,-50%);
    /*使用in动画,持续0.5秒,缓出的时间函数,停留在最后一帧*/
    animation: in 0.5s ease-out forwards;
}
/*设置鼠标离开的样式*/
.container .out{
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 1200px;
    height: 1200px;
    border-radius: 50%;
    background: #cf455f;
    transform: translate(-50%,-50%);
    /*使用out动画,持续0.5秒,缓出的时间函数,停留在最后一帧*/
    animation: out 0.5s ease-out forwards;
}
/*动画*/
/*设置鼠标进入时,元素的动画*/
@keyframes in{
    /*初始关键帧*/
    0%{
        width: 0;
        height: 0;
    }
    /*结束关键帧*/
    100%{
        width: 1200px;
        height: 1200px;
    }
}
/*设置鼠标离开时,元素的动画*/
@keyframes out{
    /*初始关键帧*/
    0%{
        width: 1200px;
        height: 1200px;
    }
    /*结束关键帧*/
    100%{
        width: 0;
        height: 0;
    }
}

效果图:

Demo1
Demo1

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是一个简单的登录、注册界面的示例代码,供你参考: HTML代码: ```html <!DOCTYPE html> <html> <head> <title>Login/Register</title> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" type="text/css" href="style.css"> </head> <body> <div class="container"> <div class="form-container"> <h2>Login</h2> <form> <label for="username">Username:</label> <input type="text" id="username" name="username" placeholder="Enter username"> <label for="password">Password:</label> <input type="password" id="password" name="password" placeholder="Enter password"> <button type="submit">Login</button> </form> </div> <div class="form-container"> <h2>Register</h2> <form> <label for="reg-username">Username:</label> <input type="text" id="reg-username" name="reg-username" placeholder="Enter username"> <label for="reg-password">Password:</label> <input type="password" id="reg-password" name="reg-password" placeholder="Enter password"> <label for="confirm-password">Confirm Password:</label> <input type="password" id="confirm-password" name="confirm-password" placeholder="Enter password again"> <button type="submit">Register</button> </form> </div> </div> </body> </html> ``` CSS代码: ```css * { box-sizing: border-box; margin: 0; padding: 0; } body { font-family: Arial, sans-serif; background-color: #f2f2f2; } .container { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; height: 100vh; } .form-container { background-color: #fff; margin: 10px; padding: 20px; border-radius: 5px; box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.2); } .form-container h2 { margin-bottom: 10px; } form { display: flex; flex-direction: column; } label { margin-top: 10px; } input { padding: 5px; margin-top: 5px; border: 1px solid #ccc; border-radius: 3px; } button { background-color: #4CAF50; color: #fff; padding: 10px; margin-top: 10px; border: none; border-radius: 3px; cursor: pointer; } button:hover { background-color: #3e8e41; } ``` 以上代码实现了一个简单的登录、注册界面,包含输入框、按钮等基本元素,并使用CSS样式美化页面。你可以在本地创建一个HTMLCSS文件,将代码复制到对应文件中,然后使用浏览器打开HTML文件,查看效果。当然,这只是一个简单的示例,实际的登录、注册功能需要更复杂的代码实现。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值