首页 > 其他分享 >原创 用户个人资料页面

原创 用户个人资料页面

时间:2024-11-18 14:19:20浏览次数:1  
标签:个人资料 color 用户 -- background rem var border 页面

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>个人资料 - QSZ</title>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css">
    <style>
        :root {
            --primary-color: #3b82f6;
            --secondary-color: #60a5fa;
            --text-color: #1f2937;
            --bg-color: #f3f4f6;
            --white: #ffffff;
            --border-color: #e5e7eb;
            --success-color: #10b981;
        }

        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
            font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
            background-color: var(--bg-color);
            color: var(--text-color);
            line-height: 1.6;
        }

        .container {
            max-width: 1000px;
            margin: 2rem auto;
            padding: 0 1rem;
        }

        .profile-header {
            background: var(--white);
            border-radius: 1rem;
            padding: 2rem;
            margin-bottom: 2rem;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
            display: flex;
            align-items: center;
            gap: 2rem;
        }

        .avatar-section {
            position: relative;
        }

        .avatar {
            width: 120px;
            height: 120px;
            border-radius: 50%;
            object-fit: cover;
            border: 4px solid var(--white);
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }

        .avatar-upload {
            position: absolute;
            bottom: 0;
            right: 0;
            background: var(--primary-color);
            color: var(--white);
            width: 32px;
            height: 32px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: background-color 0.3s ease;
        }

        .avatar-upload:hover {
            background: var(--secondary-color);
        }

        .avatar-upload input {
            display: none;
        }

        .profile-info h1 {
            font-size: 1.8rem;
            margin-bottom: 0.5rem;
        }

        .profile-info p {
            color: #6b7280;
        }

        .profile-stats {
            display: flex;
            gap: 2rem;
            margin-top: 1rem;
        }

        .stat-item {
            text-align: center;
        }

        .stat-value {
            font-size: 1.2rem;
            font-weight: 600;
            color: var(--primary-color);
        }

        .stat-label {
            font-size: 0.875rem;
            color: #6b7280;
        }

        .profile-content {
            display: grid;
            grid-template-columns: 1fr 3fr;
            gap: 2rem;
        }

        .profile-nav {
            background: var(--white);
            border-radius: 1rem;
            padding: 1.5rem;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }

        .nav-item {
            display: flex;
            align-items: center;
            gap: 1rem;
            padding: 1rem;
            color: var(--text-color);
            text-decoration: none;
            border-radius: 0.5rem;
            transition: all 0.3s ease;
        }

        .nav-item:hover,
        .nav-item.active {
            background: var(--bg-color);
            color: var(--primary-color);
        }

        .nav-item i {
            width: 20px;
        }

        .profile-form {
            background: var(--white);
            border-radius: 1rem;
            padding: 2rem;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }

        .form-section {
            margin-bottom: 2rem;
        }

        .form-section h2 {
            font-size: 1.2rem;
            margin-bottom: 1.5rem;
            padding-bottom: 0.5rem;
            border-bottom: 1px solid var(--border-color);
        }

        .form-group {
            margin-bottom: 1.5rem;
        }

        .form-group label {
            display: block;
            margin-bottom: 0.5rem;
            font-weight: 500;
        }

        .form-group input,
        .form-group textarea {
            width: 100%;
            padding: 0.75rem 1rem;
            border: 1px solid var(--border-color);
            border-radius: 0.5rem;
            font-size: 1rem;
            transition: all 0.3s ease;
        }

        .form-group input:focus,
        .form-group textarea:focus {
            outline: none;
            border-color: var(--primary-color);
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
        }

        .form-row {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 1.5rem;
        }

        .btn {
            padding: 0.75rem 1.5rem;
            border: none;
            border-radius: 0.5rem;
            font-size: 1rem;
            font-weight: 500;
            cursor: pointer;
            transition: background-color 0.3s ease;
        }

        .btn-primary {
            background: var(--primary-color);
            color: var(--white);
        }

        .btn-primary:hover {
            background: var(--secondary-color);
        }

        .btn-outline {
            background: transparent;
            border: 1px solid var(--border-color);
            color: var(--text-color);
        }

        .btn-outline:hover {
            background: var(--bg-color);
        }

        .form-actions {
            display: flex;
            justify-content: flex-end;
            gap: 1rem;
            margin-top: 2rem;
        }

        .social-links {
            display: grid;
            gap: 1rem;
        }

        .social-link {
            display: flex;
            align-items: center;
            gap: 1rem;
            padding: 0.75rem 1rem;
            border: 1px solid var(--border-color);
            border-radius: 0.5rem;
            color: var(--text-color);
            text-decoration: none;
            transition: all 0.3s ease;
        }

        .social-link:hover {
            background: var(--bg-color);
            border-color: var(--primary-color);
        }

        .social-link i {
            font-size: 1.25rem;
        }

        @media (max-width: 768px) {
            .profile-content {
                grid-template-columns: 1fr;
            }

            .form-row {
                grid-template-columns: 1fr;
            }

            .profile-header {
                flex-direction: column;
                text-align: center;
            }

            .profile-stats {
                justify-content: center;
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="profile-header">
            <div class="avatar-section">
                <img src="https://via.placeholder.com/120" alt="用户头像" class="avatar">
                <label class="avatar-upload">
                    <i class="fas fa-camera"></i>
                    <input type="file" accept="image/*">
                </label>
            </div>
            <div class="profile-info">
                <h1>北边村的富少</h1>
                <p>前端开发工程师</p>
                <div class="profile-stats">
                    <div class="stat-item">
                        <div class="stat-value">125</div>
                        <div class="stat-label">文章</div>
                    </div>
                    <div class="stat-item">
                        <div class="stat-value">12.5k</div>
                        <div class="stat-label">粉丝</div>
                    </div>
                    <div class="stat-item">
                        <div class="stat-value">89</div>
                        <div class="stat-label">收藏</div>
                    </div>
                </div>
            </div>
        </div>

        <div class="profile-content">
            <nav class="profile-nav">
                <a href="#" class="nav-item active">
                    <i class="fas fa-user"></i>
                    个人资料
                </a>
                <a href="#" class="nav-item">
                    <i class="fas fa-lock"></i>
                    账号安全
                </a>
                <a href="#" class="nav-item">
                    <i class="fas fa-bell"></i>
                    消息通知
                </a>
                <a href="#" class="nav-item">
                    <i class="fas fa-palette"></i>
                    个性化设置
                </a>
            </nav>

            <div class="profile-form">
                <form id="profileForm">
                    <div class="form-section">
                        <h2>基本信息</h2>
                        <div class="form-row">
                            <div class="form-group">
                                <label for="nickname">昵称</label>
                                <input type="text" id="nickname" value="北边村的富少">
                            </div>
                            <div class="form-group">
                                <label for="email">邮箱</label>
                                <input type="email" id="email" value="[email protected]">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="bio">个人简介</label>
                            <textarea id="bio" rows="4">热爱前端开发,分享学习经验和技术心得。</textarea>
                        </div>
                    </div>

                    <div class="form-section">
                        <h2>社交账号</h2>
                        <div class="social-links">
                            <a href="#" class="social-link">
                                <i class="fab fa-github"></i>
                                绑定 GitHub 账号
                            </a>
                            <a href="#" class="social-link">
                                <i class="fab fa-weixin"></i>
                                绑定微信账号
                            </a>
                            <a href="#" class="social-link">
                                <i class="fab fa-qq"></i>
                                绑定 QQ 账号
                            </a>
                        </div>
                    </div>

                    <div class="form-section">
                        <h2>联系方式</h2>
                        <div class="form-row">
                            <div class="form-group">
                                <label for="phone">手机号码</label>
                                <input type="tel" id="phone" placeholder="请输入手机号码">
                            </div>
                            <div class="form-group">
                                <label for="location">所在地</label>
                                <input type="text" id="location" placeholder="请输入所在地">
                            </div>
                        </div>
                    </div>

                    <div class="form-actions">
                        <button type="button" class="btn btn-outline">取消</button>
                        <button type="submit" class="btn btn-primary">保存更改</button>
                    </div>
                </form>
            </div>
        </div>
    </div>

    <script>
        // 头像上传预览
        document.querySelector('.avatar-upload input').addEventListener('change', function(e) {
            if (e.target.files && e.target.files[0]) {
                const reader = new FileReader();
                reader.onload = function(e) {
                    document.querySelector('.avatar').src = e.target.result;
                }
                reader.readAsDataURL(e.target.files[0]);
            }
        });

        // 表单提交
        document.getElementById('profileForm').addEventListener('submit', function(e) {
            e.preventDefault();
            // 这里添加表单提交逻辑
            alert('个人资料更新成功!');
        });
    </script>
</body>
</html>

 

标签:个人资料,color,用户,--,background,rem,var,border,页面
From: https://www.cnblogs.com/qsz666/p/18552531

相关文章

  • 原创 管理后台页面
    <!DOCTYPEhtml><htmllang="zh-CN"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><title>管理后台-QSZ</title>......
  • 在 Windows 操作系统中,如果用户账户因多次输入错误密码而被锁定,管理员可以使用 PowerS
    在Windows操作系统中,如果用户账户因多次输入错误密码而被锁定,管理员可以使用PowerShell命令来查看和解锁本地用户账户。以下是两个常用命令:Get-LocalUser和Unlock-LocalUser。这两个命令的作用有所不同,具体功能和区别如下:1. Get-LocalUserGet-LocalUser命令用于查看本......
  • 使用 PowerShell 的 Get-LocalUser 命令可以获取本地用户账户的详细信息。要将输出转
    使用PowerShell的Get-LocalUser命令可以获取本地用户账户的详细信息。要将输出转换为JSON格式,使用ConvertTo-Json命令,这样可以方便地查看和分析这些信息,尤其是在处理多个用户账户时。步骤说明1.使用 Get-LocalUser 获取本地用户信息Get-LocalUser命令用于列出本地......
  • SIDCHGU(SIDCHGU64 在 64 位 Windows 上)1.0e 是一个命令行实用程序,用于将 Windows 用户
    SIDCHGU-用于复制或移动用户配置文件的实用程序概述SIDCHGU(SIDCHGU64在64位Windows上)1.0e是一个命令行实用程序,用于将Windows用户配置文件(包括带有子目录的用户主目录)从一个用户复制或移动到另一个用户,适用于Windows2022/11/2019/2016/10/8.1/2012R......
  • 在阿里云快速启动Appsmith搭建前端页面
    什么是AppsmithAppsmith是一个开源的低代码开发平台,它使得开发者能够快速地构建内部工具、业务管理系统、CRM系统等。Appsmith通过提供一系列预建的UI组件(如表格、图表、表单等),以及对数据库、API调用的直接支持,简化了开发过程。开发者可以使用这些组件和服务来构建复杂的业务应用......
  • 抖音用户列表搜索采集器蓝V商家联系电话采集软件
    代码示例,用于从模拟的抖音蓝V商家信息中采集联系电话,但请注意,实际在抖音平台上未经授权采集商家信息是违反平台规定且可能涉及法律问题的,这里仅作技术演示模拟。假设我们有一个简单的结构体或类来表示抖音蓝V商家的信息,并且联系电话是以某种格式存储在一个数据字段中,以下是示......
  • 用户故事与敏捷开发
    什么是用户故事用户故事(UserStory)是用来对软件或用户有价值功能的简短描述,是对需求的一种描述。它清晰简洁的传达了用户想要的功能。它从用户角度出发,用来描述用户的需求,用来表达用户需求的方式之一。它从用户角度出发,解释了用户所期望得到的结果。用户故事清楚的解释了新功能......
  • 顶级企业如何用数据脱敏保护用户隐私!
    0前言ShardingSphere提供数据访问安全性:通过数据脱敏,完成对敏感数据的安全访问。本文介绍ShardingSphere数据脱敏功能。数据脱敏,指对敏感信息通过脱敏规则进行数据转换,实现敏感隐私数据的可靠保护。相较传统私有化部署方案,互联网应用对数据安全要求更高,涉及范围更广。根据行业......
  • gofiber: 模板: 页面上用range循环显示
    一,代码:1,controllerfunc(dc*ArticleController)ListArticle(c*fiber.Ctx)error{ //处理获取文章的逻辑 article1:=new(Article) article1.Id=1 article1.Title="三国演义毛宗岗批本" article1.Author="罗贯中" article2:=new(Article) article2.Id......
  • 「LUCKY STUN穿透」使用Cloudflare的页面规则固定和隐藏网页端口
    关于本教程索引│├─关于本教程│├─在STUN穿透环境中使用WEB服务│├─动态端口带来的麻烦│├─“隐藏端口”和固定端口│└─可用的解决方法│├─使用邮件进行通知端口变化│└─使用HTTP重定向│├─网络环境优化和STUN穿透规则设置......