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),然后在浏览器里访问页面。

相关推荐
玖笙&6 小时前
✨Vue 静态路由详解:构建应用的导航骨架(4)
前端·javascript·vue.js
这是个栗子6 小时前
(二)Vue.js 指令、事件与计算属性
前端·javascript·vue
小墨宝7 小时前
umijs 4.0学习 - 路由
前端·javascript·学习
介次别错过7 小时前
React入门
前端·javascript·react.js
细节控菜鸡7 小时前
【2025最新】ArcGIS for JS点聚合功能实现
开发语言·javascript·arcgis
破浪前行·吴7 小时前
【学习】响应系统
前端·javascript·学习
叫我詹躲躲7 小时前
Web Animation性能优化:从EffectTiming到动画合成
前端·javascript
FserSuN7 小时前
React 标准 SPA 项目 入门学习记录
前端·学习·react.js
YAY_tyy7 小时前
【Cesium 开发实战教程】第六篇:三维模型高级交互:点击查询、材质修改与动画控制
前端·javascript·3d·教程·cesium