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

相关推荐
十一.3665 小时前
37-38 for循环
前端·javascript·html
艾小码6 小时前
为什么你的JavaScript代码总是出bug?这5个隐藏陷阱太坑了!
前端·javascript
辻戋8 小时前
从零实现React Scheduler调度器
前端·react.js·前端框架
徐同保8 小时前
使用yarn@4.6.0装包,项目是react+vite搭建的,项目无法启动,报错:
前端·react.js·前端框架
Qrun8 小时前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
JELEE.9 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
小李小李不讲道理15 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
牧杉-惊蛰16 小时前
纯flex布局来写瀑布流
前端·javascript·css
社恐的下水道蟑螂19 小时前
从字符串到像素:深度解析 HTML/CSS/JS 的页面渲染全过程
javascript·css·html
行走的陀螺仪19 小时前
uni-app + Vue3 实现折叠文本(超出省略 + 展开收起)
前端·javascript·css·uni-app·vue3