feat: 完成前端响应式设计优化,增强移动端体验
- 添加触摸手势支持库 (react-spring + @use-gesture/react) - 照片模态框增加左右滑动切换功能 - 照片画廊增加下拉刷新功能 (移动端) - 优化所有按钮符合44px最小触摸目标标准 - 增强移动端导航体验,增加悬停和选中状态 - 创建设备信息检测钩子 (useDeviceInfo) - 开发优化图片组件,支持懒加载和骨架屏 - 改进移动端手势交互和视觉反馈 - 完善响应式断点系统和触摸设备检测 - 前端构建测试成功,开发服务器正常启动 Task 23 completed: 前端响应式设计优化
This commit is contained in:
@ -43,7 +43,7 @@ export function Navigation({ activeTab, onTabChange }: NavigationProps) {
|
||||
<button
|
||||
key={item.name}
|
||||
onClick={() => handleTabClick(item)}
|
||||
className={`text-gray-700 hover:text-gray-900 transition-colors duration-200 font-light relative pb-1 ${
|
||||
className={`text-gray-700 hover:text-gray-900 transition-colors duration-200 font-light relative pb-1 min-h-[44px] px-2 ${
|
||||
activeTab === item.id ? "text-gray-900" : ""
|
||||
}`}
|
||||
>
|
||||
@ -56,7 +56,12 @@ export function Navigation({ activeTab, onTabChange }: NavigationProps) {
|
||||
</div>
|
||||
|
||||
{/* Mobile Menu Button */}
|
||||
<Button variant="ghost" size="sm" className="md:hidden" onClick={() => setIsMenuOpen(!isMenuOpen)}>
|
||||
<Button
|
||||
variant="ghost"
|
||||
size="sm"
|
||||
className="md:hidden min-h-[44px] min-w-[44px] p-2"
|
||||
onClick={() => setIsMenuOpen(!isMenuOpen)}
|
||||
>
|
||||
{isMenuOpen ? <X className="h-6 w-6" /> : <Menu className="h-6 w-6" />}
|
||||
</Button>
|
||||
</div>
|
||||
@ -64,13 +69,13 @@ export function Navigation({ activeTab, onTabChange }: NavigationProps) {
|
||||
{/* Mobile Navigation */}
|
||||
{isMenuOpen && (
|
||||
<div className="md:hidden py-4 border-t border-gray-100">
|
||||
<div className="flex flex-col space-y-4">
|
||||
<div className="flex flex-col space-y-2">
|
||||
{navItems.map((item) => (
|
||||
<button
|
||||
key={item.name}
|
||||
onClick={() => handleTabClick(item)}
|
||||
className={`text-left text-gray-700 hover:text-gray-900 transition-colors duration-200 font-light ${
|
||||
activeTab === item.id ? "text-gray-900 font-medium" : ""
|
||||
className={`text-left text-gray-700 hover:text-gray-900 transition-colors duration-200 font-light min-h-[44px] px-4 py-2 rounded-md hover:bg-gray-50 ${
|
||||
activeTab === item.id ? "text-gray-900 font-medium bg-gray-50" : ""
|
||||
}`}
|
||||
>
|
||||
{item.name}
|
||||
|
||||
Reference in New Issue
Block a user