vue+css实现极简即时通讯聊天ui代码
代码语言:html
所属分类:布局界面
代码描述:vue+css实现极简即时通讯聊天ui代码,用户密码是admin和123
代码标签: vue css 极简 即时 通讯 聊天 ui 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title> IM - 可交互UI原型</title> <link type="text/css" rel="stylesheet" href="//repo.bfw.wiki/bfwrepo/css/bootstrap-icons.1.11.3.css"> <script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/vue.global.prod.3.5.17.js"></script> <style> :root { /* 主要色彩系统 */ --primary-color: #2563eb; --primary-hover: #1d4ed8; --primary-light: #eff6ff; --secondary-color: #64748b; --success-color: #059669; --warning-color: #d97706; --danger-color: #dc2626; --info-color: #0284c7; /* 中性色彩 */ --white: #ffffff; --gray-50: #f8fafc; --gray-100: #f1f5f9; --gray-200: #e2e8f0; --gray-300: #cbd5e1; --gray-400: #94a3b8; --gray-500: #64748b; --gray-600: #475569; --gray-700: #334155; --gray-800: #1e293b; --gray-900: #0f172a; /* 阴影系统 */ --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05); --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1); --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1); --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1); --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1); /* 圆角系统 */ --radius-sm: 0.375rem; --radius-md: 0.5rem; --radius-lg: 0.75rem; --radius-xl: 1rem; /* 间距系统 */ --spacing-xs: 0.25rem; --spacing-sm: 0.5rem; --spacing-md: 1rem; --spacing-lg: 1.5rem; --spacing-xl: 2rem; --spacing-2xl: 3rem; /* 字体系统 */ --font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; --font-size-xs: 0.75rem; --font-size-sm: 0.875rem; --font-size-base: 1rem; --font-size-lg: 1.125rem; --font-size-xl: 1.25rem; --font-size-2xl: 1.5rem; --font-size-3xl: 1.875rem; /* 过渡动画 */ --transition-fast: 150ms ease-in-out; --transition-normal: 250ms ease-in-out; --transition-slow: 350ms ease-in-out; } /* 全局重置和基础样式 */ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } html, body { height: 100%; font-family: var(--font-family); font-size: var(--font-size-base); line-height: 1.6; color: var(--gray-800); background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } [v-cloak] { display: none; } /* 应用容器 */ #app { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: var(--spacing-lg); } /* 加载状态 */ .app-loading { text-align: center; color: var(--white); background: rgba(255, 255, 255, 0.1); backdrop-filter: blur(10px); border: 1px solid rgba(255, 255, 255, 0.2); border-radius: var(--radius-xl); padding: var(--spacing-2xl); box-shadow: var(--shadow-xl); } .app-loading .spinner { width: 48px; height: 48px; border: 4px solid rgba(255, 255, 255, 0.2); border-left-color: var(--white); border-radius: 50%; animation: spin 1s linear infinite; margin: 0 auto var(--spacing-lg); } .app-loading p { font-size: var(--font-size-lg); font-weight: 500; } @keyframes spin { to { transform: rotate(360deg); } } /* 登录界面 */ .login-view { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; } .login-box { background: var(--white); padding: var(--spacing-2xl); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); width: 100%; max-width: 420px; border: 1px solid var(--gray-200); } .login-box h2 { font-size: var(--font-size-2xl); font-weight: 700; color: var(--gray-900); text-align: center; margin-bottom: var(--spacing-xl); } .login-box .error-msg { color: var(--danger-color); font-size: var(--font-size-sm); text-align: center; min-height: 1.5rem; margin-bottom: var(--spacing-lg); font-weight: 500; } .form-control { width: 100%; padding: 0.875rem var(--spacing-lg); margin-bottom: var(--spacing-lg); border: 2px solid var(--gray-200); border-radius: var(--radius-md); font-size: var(--font-size-base); transition: all var(--transition-fast); background: var(--gray-50); font-family: inherit; } .form-control:focus { border-color: var(--primary-color); background: var(--white); outline: none; box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1); } .form-control::placeholder { color: var(--gray-400); } /* 按钮系统 */ .btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--spacing-sm); font-weight: 600; font-size: var(--font-size-sm); line-height: 1; text-align: center; text-decoration: none; cursor: pointer; user-select: none; border: 2px solid transparent; border-radius: var(--radius-md); transition: all var(--transition-fast); font-family: inherit; white-space: nowrap; } .btn:disabled { opacity: 0.5; cursor: not-allowed; } .btn-primary { padding: 0.875rem var(--spacing-lg); color: var(--white); background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-hover) 100%); border-color: var(--primary-color); box-shadow: var(--shadow-sm); } .btn-primary:hover:not(:disabled) { background: linear-gradient(135deg, var(--primary-hover) 0%, #1e40af 100%); box-shadow: var(--shadow-md); transform: translateY(-1px); } .btn-secondary { padding: 0.75rem var(--spacing-lg); color: var(--gray-700); background: var(--white); border-color: var(--gray-300); } .btn-secondary:hover { background: var(--gray-50); border-color: var(--gray-400); } .btn-success { padding: 0.5rem 0.75rem; color: var(--white); background: var(--success-color); font-size: var(--font-size-xs); } .btn-success:hover { background: #047857; } .btn-danger { padding: 0.5rem 0.75rem; color: var(--white); background: var(--danger-color); font-size: var(--font-size-xs); } .btn-danger:hover { background: #b91c1c; } .btn-block { width: 100%; } .btn-icon { background: none; border: none; color: var(--gray-500); cursor: pointer; padding: var(--spacing-sm); border-radius: var(--radius-sm); transition: all var(--transition-fast); display: flex; align-items: center; justify-content: center; } .btn-icon:hover { background: var(--gray-100); color: var(--primary-color); } .login-box .toggle-form { text-align: center; margin-top: var(--spacing-lg); color: var(--primary-color); cursor: pointer; font-size: var(--font-size-sm); font-weight: 500; transition: color var(--transition-fast); } .login-box .toggle-form:hover { color: var(--primary-hover); } /* 聊天界面 */ .chat-view { display: flex; width: 100%; max-width: 1400px; height: 90vh; max-height: 900px; background: var(--white); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); overflow: hidden; border: 1px solid rgba(255, 255, 255, 0.2); } /* 侧边栏 */ .sidebar { width: 360px; border-right: 1px solid var(--gray-200); display: flex; flex-direction: column; background: var(--gray-50); } .sidebar-header { padding: var(--spacing-lg); border-bottom: 1px solid var(--gray-200); background: var(--white); position: relative; } .sidebar-header .user-info { display: flex; align-items: center; cursor: pointer; padding: var(--spacing-sm); border-radius: var(--radius-md); transition: background var(--transition-fast); } .sidebar-header .user-info:hover { background: var(--gray-50); } .avatar { width: 48px; height: 48px; border-radius: 50%; background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-hover) 100%); color: var(--white); display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: var(--font-size-lg); text-transform: uppercase; margin-right: var(--spacing-md); box-shadow: var(--shadow-sm); } .sidebar-header .username { font-weight: 600; font-size: var(--font-size-lg); color: var(--gray-900); } .user-menu { position: absolute; top: 90px; left: var(--spacing-lg); background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); z-index: 10; list-style: none; padding: var(--spacing-sm) 0; width: 200px; border: 1px solid var(--gray-200); } .user-menu li { padding: var(--spacing-md) var(--spacing-lg); cursor: pointer; display: flex; justify-content: space-between; align-items: center; font-size: var(--font-size-sm); font-weight: 500; color: var(--gray-700); transition: background var(--transition-fast); } .user-menu li:hover { background: var(--gray-50); color: var(--primary-color); } .request-badge { background: var(--danger-color); color: var(--white); font-size: var(--font-size-xs); padding: 2px 8px; border-radius: 10px; font-weight: 600; min-width: 20px; text-align: center; } .sidebar-header .actions { margin-top: var(--spacing-lg); display: flex; gap: var(--spacing-sm); } .sidebar-header .actions .btn { flex: 1; padding: var(--spacing-md); font-size: var(--font-size-sm); background: var(--gray-100); border: 1px solid var(--gray-200); color: var(--gray-700); font-weight: 500; } .sidebar-header .actions .btn:hover { background: var(--primary-light); border-color: var(--primary-color); color: var(--primary-color); } /* 联系人列表 */ .contact-list { flex: 1; overflow-y: auto; padding: var(--spacing-sm) 0; } .contact-item { display: flex; align-items: center; padding: var(--spacing-md) var(--spacing-lg); cursor: pointer; transition: all var(--transition-fast); position: relative; border-left: 3px solid transparent; margin: 2px var(--spacing-sm); border-radius: var(--radius-md); } .contact-item:hover { background: var(--white); box-shadow: var(--shadow-sm); } .contact-item.active { background: linear-gradient(135deg, var(--primary-light) 0%, #e0f2fe 100%); border-left-color: var(--primary-color); box-shadow: var(--shadow-sm); } .contact-item .avatar { width: 44px; height: 44px; font-size: var(--font-size-base); margin-right: var(--spacing-md); } .contact-item .contact-details { flex: 1; overflow: hidden; min-width: 0; } .contact-item .contact-name { font-weight: 600; margin-bottom: var(--spacing-xs); color: var(--gray-900); font-size: var(--font-size-sm); } .contact-item .last-message { color: var(--gray-500); font-size: var(--font-size-xs); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.4; } .unread-badge { position: absolute; top: 50%; right: var(--spacing-lg); transform: translateY(-50%); background: var(--primary-color); color: var(--white); border-radius: 12px; min-width: 24px; height: 24px; padding: 0 var(--spacing-sm); font-size: var(--font-size-xs); display: flex; align-items: center; justify-content: center; font-weight: 600; box-shadow: var(--shadow-sm); } /* 聊天主界面 */ .chat-main { flex: 1; display: flex; flex-direction: column; background: var(--white); } .chat-header { padding: var(--spacing-lg); border-bottom: 1px solid var(--gray-200); display: flex; align-items: center; ju.........完整代码请登录后点击上方下载按钮下载查看
网友评论0