React简单例子

1、设置React项目

如果你还没有一个React项目,你可以使用Create React App来创建一个。

2、在你的React项目中,新建一个新的组件文件,比如Login.jsx,并编写以下代码:

javascript 复制代码
import React, {useState, useEffect} from 'react';
import '../Styles/Login.css'; //使用css来美化界面

const Login = () => {
    const [email, setEmail] = useState('') //使用状态来保存邮箱、密码、错误信息等值
    const [password, setPassword] = useState('')
    const [error, setError] = useState('')
    const [time, setTime] = useState(0)

    //增加一个effect,返回函数在组件销毁时执行
    useEffect(() => {
        const interval = setInterval(() => {
            setTime(a=>a+1)
        }, 1000)
        return () => {
            clearInterval(interval)
        }
    }, [])

    const handleSubmit = (e) => {
        e.preventDefault()
        console.log('email:', email);
        console.log('Password:', password);

        setError('Invalid credentials');

        setEmail('')
        setPassword('')
    };

    return (
        <div className="login-container">
            <h2>Login</h2>
            <div>停留时间:{time}秒</div>
            <form onSubmit={handleSubmit}>
                <div>
                    <label>Email:</label>
                    <input type="email" value={email} onChange={(e) => setEmail(e.target.value)} required/>
                </div>
                <div>
                    <label>Password:</label>
                    <input type="password" value={password} onChange={(e) => setPassword(e.target.value)} required/>
                </div>
                {error && <div className="error">{error}</div>}
                <button type="submit">Login</button>
            </form>
        </div>
    )
};

export default Login;

Login.css

css 复制代码
.login-container {
    max-width: 400px;
    margin: 50px auto; /* 增加顶部和底部的边距以提升居中效果 */
    padding: 30px; /* 增加内边距以使内容更加宽松 */
    border: 1px solid #ccc;
    border-radius: 15px; /* 增加圆角半径以使边框更加柔和 */
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.15); /* 增加阴影的模糊半径以使阴影更加自然 */
    background-color: #f9f9f9; /* 添加背景颜色以区分界面 */
}

.login-container h2 {
    text-align: center;
    margin-bottom: 30px; /* 增加与表单元素的距离 */
    color: #333; /* 设置标题颜色 */
    font-family: Arial, sans-serif; /* 设置字体 */
}

.login-container div {
    margin-bottom: 20px; /* 适当调整间距 */
}

.login-container label {
    display: block;
    margin-bottom: 10px;
    color: #555; /* 设置标签颜色 */
}

.login-container input {
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
    border: 1px solid #ccc;
    border-radius: 5px;
    transition: border-color 0.3s; /* 添加过渡效果 */
}

.login-container input:focus {
    border-color: #007bff; /* 聚焦时改变边框颜色以提升用户体验 */
}

.login-container button {
    width: 100%;
    padding: 12px;
    background-color: #28a745;
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-size: 16px; /* 增大按钮字体 */
    transition: background-color 0.3s; /* 添加过渡效果 */
}

.login-container button:hover {
    background-color: #218838;
}

.error {
    color: red;
    text-align: center;
    margin-top: 20px; /* 适当调整间距 */
    font-size: 14px; /* 设置错误提示的字体大小 */
}

3、现在,你需要在你的应用中渲染这个登录组件。通常你会在App.js中做这件事:

javascript 复制代码
import React from 'react'
import Login from './Pages/Login.jsx'
import './App.css' //全局样式

function App() {
    return (
        <div className="App">
            <Login />
        </div>
    )
}

export default App;

4、确保你的开发服务器正在运行(npm start),然后在浏览器里访问页面。

相关推荐
大怪v5 小时前
【搞发🌸活】不信书上那套理论!亲测Javascript能卡浏览器Reader一辈子~
javascript·html·浏览器
清羽_ls5 小时前
React Hooks 核心规则&自定义 Hooks
前端·react.js·hooks
西陵5 小时前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构
Panda__Panda5 小时前
docker项目打包演示项目(数字排序服务)
运维·javascript·python·docker·容器·c#
10年前端老司机6 小时前
Promise 常见面试题(持续更新中)
前端·javascript
WebDesign_Mu9 小时前
为了庆祝2025英雄联盟全球总决赛开启,我用HTML+CSS+JS制作了LOL官方网站
javascript·css·html
噢,我明白了9 小时前
前端js 常见算法面试题目详解
前端·javascript·算法
学编程的小虎9 小时前
用 Python + Vue3 打造超炫酷音乐播放器:网易云歌单爬取 + Three.js 波形可视化
开发语言·javascript·python
做好一个小前端9 小时前
后端接口获取到csv格式内容并导出,拒绝乱码
前端·javascript·html
mapbar_front10 小时前
react项目开发—关于代码架构/规范探讨
前端·react.js