完善代码框架
This commit is contained in:
		
							parent
							
								
									0f88a14122
								
							
						
					
					
						commit
						9d09c8c8c9
					
				
							
								
								
									
										29
									
								
								css/body.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								css/body.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | |||||||
|  | /* 基本样式重置 */ | ||||||
|  | body, html { | ||||||
|  |     margin: 0; | ||||||
|  |     padding: 0; | ||||||
|  |     font-family: Arial, sans-serif; /* 设置页面的默认字体 */ | ||||||
|  |     background-color:#f4f4f4; | ||||||
|  | }  | ||||||
|  | 
 | ||||||
|  | /* 禁用页面滚动样式 */ | ||||||
|  | body.no-scroll { | ||||||
|  |     overflow: hidden;  /* 禁止页面滚动 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 主内容区 */ | ||||||
|  | .main-content { | ||||||
|  |     margin-left: 270px; | ||||||
|  |     margin-right: 20px; | ||||||
|  |     margin-top: 14px; /* 增加主内容区的上边距 */ | ||||||
|  |     padding: 20px; | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     justify-content: space-between; | ||||||
|  |     z-index: 1;  /* 确保内容在侧边栏下方 */ | ||||||
|  |     position: relative;  /* 确保相对定位 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .content { | ||||||
|  |     flex: 3 1 600px; /* 允许内容区域在可用空间内缩放 */ | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								css/font.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								css/font.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | |||||||
|  | /* 使用 @font-face 引用本地字体 */ | ||||||
|  | @font-face { | ||||||
|  |     font-family: 'Pacifico'; /* 字体名称 */ | ||||||
|  |     src: url('../font/Pacifico.ttf') format('truetype'); /* 设置 .ttf 格式 */ | ||||||
|  |     font-weight: normal; | ||||||
|  |     font-style: normal; | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								css/footer.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								css/footer.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | |||||||
|  | /* 页脚样式 - 默认 (电脑设备) */ | ||||||
|  | footer { | ||||||
|  |     background-color: rgba(51, 51, 51, 0.5); /* 半透明背景 */ | ||||||
|  |     color: white; | ||||||
|  |     display: flex;  /* 使用 flex 布局 */ | ||||||
|  |     justify-content: center;  /* 水平居中 */ | ||||||
|  |     align-items: center;  /* 垂直居中 */ | ||||||
|  |     padding: 0px; | ||||||
|  |     position: fixed; | ||||||
|  |     left: 0; | ||||||
|  |     right: 0; | ||||||
|  |     bottom: 0; | ||||||
|  |     font-size: 14px; | ||||||
|  |     max-height: 30px; | ||||||
|  |     z-index: 2000;  /* 提升侧边栏的层级 */ | ||||||
|  | } | ||||||
							
								
								
									
										79
									
								
								css/header.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								css/header.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,79 @@ | |||||||
|  | /* 头部样式 */ | ||||||
|  | header { | ||||||
|  |     position: fixed; | ||||||
|  |     top: 0; | ||||||
|  |     left: 0; | ||||||
|  |     width: 100%; | ||||||
|  |     background-color: #ffffff; | ||||||
|  |     color: #fff; | ||||||
|  |     padding: 10px; | ||||||
|  |     display: flex; | ||||||
|  |     justify-content: space-between; | ||||||
|  |     align-items: center; | ||||||
|  |     z-index: 3000; | ||||||
|  |     transition: all 1s ease; /* 为头部的尺寸变化和样式变化添加过渡效果 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 按钮的基础样式 */ | ||||||
|  | header .toggle-menu { | ||||||
|  |     display: inline-block; | ||||||
|  |     font-size: 24px; | ||||||
|  |     background: none; | ||||||
|  |     border: none; | ||||||
|  |     color: rgb(235, 10, 10); | ||||||
|  |     cursor: pointer; | ||||||
|  |     margin-right: 20px;  /* 设置右边距 */ | ||||||
|  |     transition: transform 0.3s ease-in-out;  /* 添加平滑过渡效果 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 悬停效果,按钮背景颜色变化 */ | ||||||
|  | header .toggle-menu:hover { | ||||||
|  |     background-color: rgba(235, 10, 10, 0.1);  /* 增加轻微的背景色变化 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 头部全屏按钮样式(仅大屏幕显示) */ | ||||||
|  | #fullscreen-button { | ||||||
|  |     position: absolute; | ||||||
|  |     right: 16px; | ||||||
|  |     top: 0px; | ||||||
|  |     background: none; | ||||||
|  |     border: none; | ||||||
|  |     cursor: pointer; | ||||||
|  |     font-size: 32px; | ||||||
|  |     display: flex; | ||||||
|  |     align-items: center; | ||||||
|  |     transition: top 0.3s ease,transform 0.3s ease-in-out, padding 0.3s ease-in-out; /* 平滑放大动画 */ | ||||||
|  |     transform-origin: center center; /* 确保放大时的中心不变 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #fullscreen-button:hover { | ||||||
|  |     transform: scale(1.20); /* 悬停时上下左右均匀放大 5% */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #search-input { | ||||||
|  |     height: 20px; | ||||||
|  |     width: 500px; | ||||||
|  |     display: inline-block; | ||||||
|  |     border: 1px solid #ccc; | ||||||
|  |     border-radius: 20px; | ||||||
|  |     padding: 5px 15px; | ||||||
|  |     transition: width 0.3s ease, padding 0.3s ease, top 0.3s ease; /* 加入 top 过渡效果 */ | ||||||
|  |     outline: none; | ||||||
|  |     background-color: #fff; | ||||||
|  |     text-align: center; | ||||||
|  |     margin-bottom: 20px; | ||||||
|  |     position: fixed; /* 固定定位 */ | ||||||
|  |     top: 10px; /* 初始位置距离顶部20px */ | ||||||
|  |     left: 50%; | ||||||
|  |     transform: translateX(-50%); /* 居中显示 */ | ||||||
|  |     z-index: 1000; /* 确保在顶部 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 鼠标悬停时搜索框展开 */ | ||||||
|  | #search-input:hover, | ||||||
|  | #search-input:focus { | ||||||
|  |     width: 600px; /* 展开宽度 */ | ||||||
|  |     padding: 5px 20px; /* 调整内边距 */ | ||||||
|  |     box-shadow: 0 0 5px rgba(0, 0, 0, 0.2); /* 添加阴影效果 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
							
								
								
									
										69
									
								
								css/max_width.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								css/max_width.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,69 @@ | |||||||
|  | /* 响应式设计 */ | ||||||
|  | @media (max-width: 768px) { | ||||||
|  |     #fullscreen-button { | ||||||
|  |         display: none; /* 小屏幕隐藏头部全屏按钮 */ | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     #sidebar-fullscreen-button { | ||||||
|  |         display: flex; /* 小屏幕显示侧边栏全屏按钮 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #search-input { | ||||||
|  |         width: 50%; /* 设置宽度为屏幕的50% */ | ||||||
|  |         padding: 5px 15px; | ||||||
|  |         top: 10px; | ||||||
|  |         left: 50%; /* 使搜索框居中 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #search-input:hover, | ||||||
|  |     #search-input:focus { | ||||||
|  |         width: 60%; /* 展开宽度 */ | ||||||
|  |         padding: 5px 20px; /* 调整内边距 */ | ||||||
|  |         box-shadow: 0 0 5px rgba(0, 0, 0, 0.2); /* 添加阴影效果 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /* 小屏幕时侧边栏 */ | ||||||
|  |     .sidebar { | ||||||
|  |         width: 80%;  /* 设置侧边栏宽度为60% */ | ||||||
|  |         bottom: 0; | ||||||
|  |         transform: translateX(-100%);  /* 默认隐藏侧边栏 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     .sidebar.open { | ||||||
|  |         transform: translateX(0); | ||||||
|  |         bottom: 0; | ||||||
|  |         width: 80%;  /* 确保侧边栏在打开时宽度为60% */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /* 小屏幕时主内容区 */ | ||||||
|  |     .main-content { | ||||||
|  |         margin-left:  0px;  /* 小屏幕时移除左边距 */ | ||||||
|  |         margin-right: 0px;  /* 小屏幕时右边距减小 */ | ||||||
|  |         margin-top: 60px;  /* 小屏幕时稍微减小上边距 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /* 小屏幕时头部 */ | ||||||
|  |     header { | ||||||
|  |         height: 40px;  /* 设置头部高度为50px */ | ||||||
|  |         justify-content: space-between; /* 保持头部内容在两端 */ | ||||||
|  |         align-items: center; /* 垂直居中内容 */ | ||||||
|  |     } | ||||||
|  |     /* 小屏幕时菜单按钮 */ | ||||||
|  |     header .toggle-menu { | ||||||
|  |         display: block;  /* 在小屏幕时显示菜单按钮 */ | ||||||
|  |         font-size: 24px; | ||||||
|  |         background: none; | ||||||
|  |         border: none; | ||||||
|  |         color: rgb(235, 10, 10); | ||||||
|  |         cursor: pointer; | ||||||
|  |         position: absolute; | ||||||
|  |         top: 10px; /* 距离顶部20px */ | ||||||
|  |         right: 14px; /* 距离右侧20px */ | ||||||
|  |         transition: transform 0.3s ease-in-out;  /* 添加平滑过渡效果 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /* 悬停效果,按钮背景颜色变化 */ | ||||||
|  |     header .toggle-menu:hover { | ||||||
|  |         background-color: rgba(235, 10, 10, 0.1);  /* 增加轻微的背景色变化 */ | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										25
									
								
								css/min_width.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								css/min_width.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | @media (min-width: 768px) { | ||||||
|  |     header { | ||||||
|  |         background: none; /* 去掉头部背景色 */ | ||||||
|  |         box-shadow: none; /* 去掉头部阴影 */ | ||||||
|  |         height: auto; /* 自动高度适应搜索框 */ | ||||||
|  |         padding: 0; /* 去掉多余的内边距 */ | ||||||
|  |         top: 10px; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #fullscreen-button { | ||||||
|  |         display: flex; /* 小屏幕隐藏头部全屏按钮 */ | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     #sidebar-fullscreen-button { | ||||||
|  |         display: none; /* 小屏幕显示侧边栏全屏按钮 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #search-input { | ||||||
|  |         margin: 0 auto; /* 搜索框居中显示 */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     header .toggle-menu { | ||||||
|  |         display: none;  /* 在小屏幕时显示菜单按钮 */ | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										87
									
								
								css/sidebar.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								css/sidebar.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,87 @@ | |||||||
|  | /* 侧边栏 */ | ||||||
|  | .sidebar { | ||||||
|  |     position: fixed; | ||||||
|  |     top: -30px; | ||||||
|  |     left: 0; | ||||||
|  |     width: 250px; | ||||||
|  |     bottom: 24px; | ||||||
|  |     background-color: #f4f4f4; | ||||||
|  |     color: rgb(100, 99, 99); /* logo颜色 */ | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     align-items: center;  /* 水平居中 */ | ||||||
|  |     padding: 20px; | ||||||
|  |     transition: transform 0.3s ease-in-out; | ||||||
|  |     z-index: 2000; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | .logo { | ||||||
|  |     font-family: 'Pacifico', cursive; /* 使用本地字体 Pacifico */ | ||||||
|  |     margin: 0; | ||||||
|  |     padding-top: 48px; | ||||||
|  |     text-align: center; /* 确保整个 logo 居中 */ | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; /* 将 part1 和 part2 垂直排列 */ | ||||||
|  |     align-items: center; /* 确保每个部分居中 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .logo .part1 { | ||||||
|  |     font-size: 50px; /* "ream" 字体较大 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .logo .part2 { | ||||||
|  |     font-size: 40px; /* ".life" 字体较小 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 侧边栏链接的基础样式 */ | ||||||
|  | .sidebar-link { | ||||||
|  |     position: relative; | ||||||
|  |     font-size: 22px; | ||||||
|  |     font-weight: bold; | ||||||
|  |     margin-top: 48px; | ||||||
|  |     color: rgb(117, 115, 115); | ||||||
|  |     text-decoration: none;  /* 去掉默认的下划线 */ | ||||||
|  |     display: inline-block; | ||||||
|  |     padding: 10px 20px; | ||||||
|  |     background-color: #f4f4f4; | ||||||
|  |     transition: all 0.3s ease;  /* 添加平滑过渡效果 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 侧边栏链接内容的容器 */ | ||||||
|  | .sidebar-link .link-content { | ||||||
|  |     display: flex; | ||||||
|  |     background-color: #f4f4f4; | ||||||
|  |     align-items: center;  /* 确保文字和图标垂直居中 */ | ||||||
|  |     transition: transform 0.3s ease;  /* 添加平滑过渡 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 悬停时图标和文字一起上浮 */ | ||||||
|  | .sidebar-link:hover .link-content { | ||||||
|  |     transform: translateY(-3px);  /* 向上浮起5px */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 图标样式 */ | ||||||
|  | .sidebar-link .icon { | ||||||
|  |     margin-right: 10px; /* 给图标和文字之间留点空隙 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 悬停时改变链接的颜色 */ | ||||||
|  | .sidebar-link:hover { | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 按钮文本和图标的状态样式 */ | ||||||
|  | .sidebar-link.fullscreen .icon { | ||||||
|  |     transform: rotate(90deg);  /* 图标旋转 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 退出全屏时的样式 */ | ||||||
|  | .sidebar-link.fullscreen span { | ||||||
|  |     content: "退出全屏";  /* 修改文本为"退出全屏" */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .sidebar { | ||||||
|  |     flex: 1 1 250px; /* 允许侧边栏在可用空间内缩放 */ | ||||||
|  | } | ||||||
							
								
								
									
										105
									
								
								css/toolcard.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								css/toolcard.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,105 @@ | |||||||
|  | /* 为整个工具卡片添加链接样式 */ | ||||||
|  | .tool-card-link { | ||||||
|  |     text-decoration: none; /* 去掉链接的下划线 */ | ||||||
|  | } | ||||||
|  | /* 保证工具卡片正常排列 */ | ||||||
|  | .tools-grid { | ||||||
|  |     display: grid; | ||||||
|  |     grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); | ||||||
|  |     gap: 20px; | ||||||
|  |     padding: 20px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 保证工具卡片的顺序 */ | ||||||
|  | .tool-card { | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; /* 使 logo 在上,名称在下 */ | ||||||
|  |     align-items: flex-start; /* 左对齐 */ | ||||||
|  |     background: white; | ||||||
|  |     border-radius: 8px; | ||||||
|  |     box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); | ||||||
|  |     padding: 20px; | ||||||
|  |     text-align: left; /* 左对齐 */ | ||||||
|  |     min-height: 180px; | ||||||
|  |     transition: transform 0.5s ease, box-shadow 0.5s ease; /* 工具卡片动画时间设置为 0.5s */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 工具卡片动画完成状态 */ | ||||||
|  | .tool-card.animated { | ||||||
|  |     opacity: 1; | ||||||
|  |     transform: translateY(0); /* 恢复到正常位置 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 工具卡片悬停效果 */ | ||||||
|  | .tool-card:hover { | ||||||
|  |     transform: scale(1.03); | ||||||
|  |     box-shadow: 0 8px 15px rgba(0, 0, 0, 0.2); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 工具卡片logo样式 */ | ||||||
|  | .tool-logo { | ||||||
|  |     margin-left: 30px; | ||||||
|  |     margin-top: 10px; | ||||||
|  |     width: 50px;  /* 设置logo的宽度 */ | ||||||
|  |     height: 50px; | ||||||
|  |     margin-bottom: 10px;  /* 给logo和名称之间留出间距 */ | ||||||
|  |     border-radius: 8px;  /* 设置圆角矩形 */ | ||||||
|  |     object-fit: cover; /* 保证图片不会被拉伸或变形 */ | ||||||
|  |     display:block; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 工具名称的样式 */ | ||||||
|  | .tool-name { | ||||||
|  |     margin-left: 30px; | ||||||
|  |     margin-top: 10px; | ||||||
|  |     font-size: 20px; | ||||||
|  |     font-weight: bold; | ||||||
|  |     color: #333; | ||||||
|  |     text-decoration: none; | ||||||
|  |     position: relative; /* 使下划线定位相对 */ | ||||||
|  |     display: inline-block; /* 确保工具名称独占一行 */ | ||||||
|  |     text-align: left; /* 左对齐 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 工具名称的下划线效果 */ | ||||||
|  | .tool-name::after { | ||||||
|  |     content: ""; | ||||||
|  |     position: absolute; | ||||||
|  |     bottom: -5px; | ||||||
|  |     left: 0; | ||||||
|  |     width: 0; | ||||||
|  |     height: 2px; | ||||||
|  |     background-color: black; | ||||||
|  |     transition: width 0.3s ease; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .tool-name:hover::after { | ||||||
|  |     width: 100%;  /* 让下划线横跨整个文字 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 分类标签样式 */ | ||||||
|  | .tool-category { | ||||||
|  |     display: inline-block; /* 使标签处于同一行 */ | ||||||
|  |     padding: 4px 16px; /* 胶囊形状的内边距,横向较宽 */ | ||||||
|  |     background-color: #fc8f8f; /* 背景颜色 */ | ||||||
|  |     color: #ffffff; /* 文字颜色 */ | ||||||
|  |     font-size: 10px; /* 字体大小 */ | ||||||
|  |     font-weight: bold; /* 加粗字体 */ | ||||||
|  |     border-radius: 50px; /* 设置圆角,形成胶囊形状 */ | ||||||
|  |     margin-left: 30px; | ||||||
|  |     margin-top: 10px; /* 给标签和描述之间留出间距 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 工具描述样式 */ | ||||||
|  | .card-description { | ||||||
|  |     font-size: 14px; | ||||||
|  |     color: #777; | ||||||
|  |     margin-left: 30px; | ||||||
|  |     margin-top: 10px;  /* 给描述添加上边距 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* 悬停效果 */ | ||||||
|  | .tool-card:hover { | ||||||
|  |     transform: scale(1.03); | ||||||
|  |     box-shadow: 0 8px 15px rgba(0, 0, 0, 0.2); | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								index.html
									
									
									
									
									
								
							| @ -4,7 +4,14 @@ | |||||||
|     <meta charset="UTF-8"> |     <meta charset="UTF-8"> | ||||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no"> |     <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no"> | ||||||
|     <title>DreamLife|ToolBox</title> |     <title>DreamLife|ToolBox</title> | ||||||
|     <link rel="stylesheet" href="styles.css"> |     <link rel="stylesheet" href="css/body.css"> | ||||||
|  |     <link rel="stylesheet" href="css/font.css"> | ||||||
|  |     <link rel="stylesheet" href="css/footer.css"> | ||||||
|  |     <link rel="stylesheet" href="css/header.css"> | ||||||
|  |     <link rel="stylesheet" href="css/max_width.css"> | ||||||
|  |     <link rel="stylesheet" href="css/min_width.css"> | ||||||
|  |     <link rel="stylesheet" href="css/sidebar.css"> | ||||||
|  |     <link rel="stylesheet" href="css/toolcard.css"> | ||||||
|     <meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate"> |     <meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate"> | ||||||
|     <meta http-equiv="Pragma" content="no-cache"> |     <meta http-equiv="Pragma" content="no-cache"> | ||||||
|     <meta http-equiv="Expires" content="0"> |     <meta http-equiv="Expires" content="0"> | ||||||
| @ -195,6 +202,9 @@ | |||||||
|         <p>© 2025 DreamLife 版权所有</p> |         <p>© 2025 DreamLife 版权所有</p> | ||||||
|     </footer> |     </footer> | ||||||
| 
 | 
 | ||||||
|     <script src="scripts.js"></script> |     <script src="javascape/full_button.js"></script> | ||||||
|  |     <script src="javascape/scroll.js"></script> | ||||||
|  |     <script src="javascape/search.js"></script> | ||||||
|  |     <script src="javascape/sidebar.js"></script> | ||||||
| </body> | </body> | ||||||
| </html> | </html> | ||||||
|  | |||||||
							
								
								
									
										48
									
								
								javascape/full_button.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								javascape/full_button.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,48 @@ | |||||||
|  | // 获取两个全屏按钮
 | ||||||
|  | const fullscreenButton = document.getElementById('fullscreen-button'); | ||||||
|  | const sidebarFullscreenButton = document.getElementById('sidebar-fullscreen-button'); | ||||||
|  | 
 | ||||||
|  | // 绑定全屏切换事件
 | ||||||
|  | function toggleFullscreen() { | ||||||
|  |     if (!document.fullscreenElement) { | ||||||
|  |         if (document.documentElement.requestFullscreen) { | ||||||
|  |             document.documentElement.requestFullscreen(); | ||||||
|  |         } else if (document.documentElement.mozRequestFullScreen) { | ||||||
|  |             document.documentElement.mozRequestFullScreen(); | ||||||
|  |         } else if (document.documentElement.webkitRequestFullscreen) { | ||||||
|  |             document.documentElement.webkitRequestFullscreen(); | ||||||
|  |         } else if (document.documentElement.msRequestFullscreen) { | ||||||
|  |             document.documentElement.msRequestFullscreen(); | ||||||
|  |         } | ||||||
|  |         updateFullscreenButton(true); | ||||||
|  |     } else { | ||||||
|  |         if (document.exitFullscreen) { | ||||||
|  |             document.exitFullscreen(); | ||||||
|  |         } else if (document.mozCancelFullScreen) { | ||||||
|  |             document.mozCancelFullScreen(); | ||||||
|  |         } else if (document.webkitExitFullscreen) { | ||||||
|  |             document.webkitExitFullscreen(); | ||||||
|  |         } else if (document.msExitFullscreen) { | ||||||
|  |             document.msExitFullscreen(); | ||||||
|  |         } | ||||||
|  |         updateFullscreenButton(false); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新按钮文本和图标
 | ||||||
|  | function updateFullscreenButton(isFullscreen) { | ||||||
|  |     const buttons = [fullscreenButton, sidebarFullscreenButton]; | ||||||
|  |     buttons.forEach(button => { | ||||||
|  |         if (isFullscreen) { | ||||||
|  |             button.querySelector('span').textContent = '退出'; | ||||||
|  |             button.querySelector('.icon').innerHTML = '↵'; // 退出全屏图标
 | ||||||
|  |         } else { | ||||||
|  |             button.querySelector('span').textContent = '全屏'; | ||||||
|  |             button.querySelector('.icon').innerHTML = '⛶'; // 全屏图标
 | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 绑定点击事件
 | ||||||
|  | fullscreenButton.addEventListener('click', toggleFullscreen); | ||||||
|  | sidebarFullscreenButton.addEventListener('click', toggleFullscreen); | ||||||
							
								
								
									
										22
									
								
								javascape/scroll.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								javascape/scroll.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | const searchBox = document.getElementById('search-input');  // 使用不同的名称避免重复声明
 | ||||||
|  | const fullButton = document.getElementById('fullscreen-button'); | ||||||
|  | 
 | ||||||
|  | // 监听滚动事件
 | ||||||
|  | window.addEventListener('scroll', function() { | ||||||
|  |     const scrollTop = window.scrollY || document.documentElement.scrollTop; // 获取滚动的距离
 | ||||||
|  | 
 | ||||||
|  |     if (scrollTop > 50) {  // 当页面滚动超过50px时
 | ||||||
|  |         searchBox.style.top = '-50px'; // 将搜索框移出视口
 | ||||||
|  |         fullscreenButton.style.top = '-50px'; // 让全屏按钮同步隐藏
 | ||||||
|  |     } else { | ||||||
|  |         searchBox.style.top = '10px'; // 恢复到初始位置
 | ||||||
|  |         fullscreenButton.style.top = '0px'; // 让全屏按钮同步恢复
 | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 页面加载完成后滚动到顶部
 | ||||||
|  | window.addEventListener('load', function() { | ||||||
|  |     setTimeout(function() { | ||||||
|  |         window.scrollTo(0, 0);  // 将页面滚动到顶部
 | ||||||
|  |     }, 100);  // 延迟 100ms 执行,确保页面已完全加载
 | ||||||
|  | }); | ||||||
							
								
								
									
										55
									
								
								javascape/search.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								javascape/search.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | |||||||
|  | // 获取搜索框输入和所有工具卡片
 | ||||||
|  | const searchInput = document.getElementById('search-input'); | ||||||
|  | const toolCards = document.querySelectorAll('.tool-card'); | ||||||
|  | 
 | ||||||
|  | // 监听搜索框的输入事件
 | ||||||
|  | searchInput.addEventListener('input', function() { | ||||||
|  |     const searchTerm = searchInput.value.toLowerCase().trim();  // 获取搜索关键词并转换为小写
 | ||||||
|  | 
 | ||||||
|  |     // 过滤工具卡片
 | ||||||
|  |     filterCards(searchTerm); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 过滤工具卡片
 | ||||||
|  | function filterCards(searchTerm) { | ||||||
|  |     const filteredCards = Array.from(toolCards).filter(card => { | ||||||
|  |         const title = card.querySelector('.tool-name').textContent.toLowerCase(); | ||||||
|  |         const description = card.querySelector('.card-description').textContent.toLowerCase(); | ||||||
|  |         return title.includes(searchTerm) || description.includes(searchTerm); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     // 更新卡片布局
 | ||||||
|  |     updateCardLayout(filteredCards, searchTerm); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新卡片布局,确保卡片顺序正确
 | ||||||
|  | function updateCardLayout(filteredCards, searchTerm) { | ||||||
|  |     const container = document.querySelector('.tools-grid'); | ||||||
|  |     container.innerHTML = '';  // 清空容器中的所有卡片
 | ||||||
|  | 
 | ||||||
|  |     if (searchTerm === '') { | ||||||
|  |         // 如果搜索框为空,恢复原始顺序
 | ||||||
|  |         toolCards.forEach(card => container.appendChild(card)); | ||||||
|  |     } else { | ||||||
|  |         // 搜索时按顺序添加匹配的卡片
 | ||||||
|  |         filteredCards.forEach(card => container.appendChild(card)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // 确保跳转链接依然有效
 | ||||||
|  |     addLinkFunctionality(filteredCards); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 为每个卡片的链接添加跳转功能
 | ||||||
|  | function addLinkFunctionality(cards) { | ||||||
|  |     cards.forEach(card => { | ||||||
|  |         const link = card.querySelector('.tool-card-link');  // 获取卡片中的链接元素
 | ||||||
|  |         if (link) { | ||||||
|  |             // 确保链接点击时会跳转(无论是旧标签还是新标签)
 | ||||||
|  |             link.addEventListener('click', function(event) { | ||||||
|  |                 // 如果需要额外的功能(比如日志记录等),可以插入代码
 | ||||||
|  |                 // 例如:console.log('Tool clicked:', link.href);
 | ||||||
|  |                 // 无需手动修改 target="_blank",浏览器会根据 <a> 标签的设置自动处理
 | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | } | ||||||
							
								
								
									
										81
									
								
								javascape/sidebar.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								javascape/sidebar.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,81 @@ | |||||||
|  | // 获取按钮和侧边栏元素
 | ||||||
|  | const menuButton = document.querySelector('.toggle-menu'); | ||||||
|  | const sidebar = document.getElementById('sidebar'); | ||||||
|  | 
 | ||||||
|  | // 侧边栏切换功能
 | ||||||
|  | menuButton.addEventListener('click', function(event) { | ||||||
|  |     event.stopPropagation();  // 阻止事件冒泡,避免触发文档点击事件
 | ||||||
|  |     toggleSidebar();  // 调用切换侧边栏函数
 | ||||||
|  |     toggleRotation();  // 调用旋转按钮函数
 | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 侧边栏元素和按钮
 | ||||||
|  | function toggleSidebar() { | ||||||
|  |     sidebar.classList.toggle('open');  // 切换侧边栏的显示/隐藏
 | ||||||
|  |     if (sidebar.classList.contains('open')) { | ||||||
|  |         document.body.classList.add('no-scroll'); // 禁用滚动
 | ||||||
|  |     } else { | ||||||
|  |         document.body.classList.remove('no-scroll'); // 恢复滚动
 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 检查侧边栏的状态,更新按钮显示/隐藏
 | ||||||
|  | function updateMenuButtonVisibility() { | ||||||
|  |     if (window.innerWidth <= 768) {  // 小屏幕显示菜单按钮
 | ||||||
|  |         menuButton.style.display = 'block'; | ||||||
|  |     } else {  // 大屏幕上不显示菜单按钮,侧边栏始终可见
 | ||||||
|  |         menuButton.style.display = 'none'; | ||||||
|  |         if (sidebar.classList.contains('open')) { | ||||||
|  |             sidebar.classList.add('open'); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 监听窗口大小变化,确保菜单按钮的显示和隐藏正确
 | ||||||
|  | window.addEventListener('resize', function() { | ||||||
|  |     updateMenuButtonVisibility(); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 初始化时检查菜单按钮的显示状态
 | ||||||
|  | updateMenuButtonVisibility(); | ||||||
|  | 
 | ||||||
|  | // 监听点击事件,点击侧边栏外部区域关闭侧边栏
 | ||||||
|  | document.addEventListener('click', function(event) { | ||||||
|  |     const isClickInsideSidebar = sidebar.contains(event.target); | ||||||
|  |     const isClickInsideButton = menuButton.contains(event.target); | ||||||
|  | 
 | ||||||
|  |     // 如果点击的地方不在侧边栏和按钮内部,并且侧边栏是打开的,则关闭侧边栏
 | ||||||
|  |     if (!isClickInsideSidebar && !isClickInsideButton && sidebar.classList.contains('open')) { | ||||||
|  |         sidebar.classList.remove('open');  // 关闭侧边栏
 | ||||||
|  |         menuButton.classList.remove('rotated');  // 恢复按钮横向
 | ||||||
|  |         document.body.classList.remove('no-scroll'); // 允许滚动
 | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 阻止点击侧边栏时关闭侧边栏
 | ||||||
|  | sidebar.addEventListener('click', function(event) { | ||||||
|  |     event.stopPropagation();  // 阻止事件冒泡,防止点击侧边栏时关闭
 | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 动画效果
 | ||||||
|  | function animateToolCards() { | ||||||
|  |     const toolCards = document.querySelectorAll('.tool-card'); | ||||||
|  |     toolCards.forEach((card, index) => { | ||||||
|  |         card.style.transitionDelay = `${index * 100}ms`; // 按顺序延迟动画
 | ||||||
|  |         card.classList.add('animated'); // 添加动画类
 | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | ; | ||||||
|  | 
 | ||||||
|  | // 禁用双指缩放
 | ||||||
|  | document.addEventListener('touchstart', function(e) { | ||||||
|  |     if (e.touches.length > 1) {  // 如果检测到多于一个手指
 | ||||||
|  |         e.preventDefault();  // 阻止默认缩放行为
 | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | document.addEventListener('touchmove', function(e) { | ||||||
|  |     if (e.touches.length > 1) {  // 如果检测到多于一个手指
 | ||||||
|  |         e.preventDefault();  // 阻止默认缩放行为
 | ||||||
|  |     } | ||||||
|  | }); | ||||||
							
								
								
									
										209
									
								
								scripts.js
									
									
									
									
									
								
							
							
						
						
									
										209
									
								
								scripts.js
									
									
									
									
									
								
							| @ -1,209 +0,0 @@ | |||||||
| const searchBox = document.getElementById('search-input');  // 使用不同的名称避免重复声明
 |  | ||||||
| const fullButton = document.getElementById('fullscreen-button'); |  | ||||||
| 
 |  | ||||||
| // 监听滚动事件
 |  | ||||||
| window.addEventListener('scroll', function() { |  | ||||||
|     const scrollTop = window.scrollY || document.documentElement.scrollTop; // 获取滚动的距离
 |  | ||||||
| 
 |  | ||||||
|     if (scrollTop > 50) {  // 当页面滚动超过50px时
 |  | ||||||
|         searchBox.style.top = '-50px'; // 将搜索框移出视口
 |  | ||||||
|         fullscreenButton.style.top = '-50px'; // 让全屏按钮同步隐藏
 |  | ||||||
|     } else { |  | ||||||
|         searchBox.style.top = '10px'; // 恢复到初始位置
 |  | ||||||
|         fullscreenButton.style.top = '0px'; // 让全屏按钮同步恢复
 |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 获取按钮和侧边栏元素
 |  | ||||||
| const menuButton = document.querySelector('.toggle-menu'); |  | ||||||
| const sidebar = document.getElementById('sidebar'); |  | ||||||
| 
 |  | ||||||
| // 侧边栏切换功能
 |  | ||||||
| menuButton.addEventListener('click', function(event) { |  | ||||||
|     event.stopPropagation();  // 阻止事件冒泡,避免触发文档点击事件
 |  | ||||||
|     toggleSidebar();  // 调用切换侧边栏函数
 |  | ||||||
|     toggleRotation();  // 调用旋转按钮函数
 |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 侧边栏元素和按钮
 |  | ||||||
| function toggleSidebar() { |  | ||||||
|     sidebar.classList.toggle('open');  // 切换侧边栏的显示/隐藏
 |  | ||||||
|     if (sidebar.classList.contains('open')) { |  | ||||||
|         document.body.classList.add('no-scroll'); // 禁用滚动
 |  | ||||||
|     } else { |  | ||||||
|         document.body.classList.remove('no-scroll'); // 恢复滚动
 |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 检查侧边栏的状态,更新按钮显示/隐藏
 |  | ||||||
| function updateMenuButtonVisibility() { |  | ||||||
|     if (window.innerWidth <= 768) {  // 小屏幕显示菜单按钮
 |  | ||||||
|         menuButton.style.display = 'block'; |  | ||||||
|     } else {  // 大屏幕上不显示菜单按钮,侧边栏始终可见
 |  | ||||||
|         menuButton.style.display = 'none'; |  | ||||||
|         if (sidebar.classList.contains('open')) { |  | ||||||
|             sidebar.classList.add('open'); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 监听窗口大小变化,确保菜单按钮的显示和隐藏正确
 |  | ||||||
| window.addEventListener('resize', function() { |  | ||||||
|     updateMenuButtonVisibility(); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 初始化时检查菜单按钮的显示状态
 |  | ||||||
| updateMenuButtonVisibility(); |  | ||||||
| 
 |  | ||||||
| // 监听点击事件,点击侧边栏外部区域关闭侧边栏
 |  | ||||||
| document.addEventListener('click', function(event) { |  | ||||||
|     const isClickInsideSidebar = sidebar.contains(event.target); |  | ||||||
|     const isClickInsideButton = menuButton.contains(event.target); |  | ||||||
| 
 |  | ||||||
|     // 如果点击的地方不在侧边栏和按钮内部,并且侧边栏是打开的,则关闭侧边栏
 |  | ||||||
|     if (!isClickInsideSidebar && !isClickInsideButton && sidebar.classList.contains('open')) { |  | ||||||
|         sidebar.classList.remove('open');  // 关闭侧边栏
 |  | ||||||
|         menuButton.classList.remove('rotated');  // 恢复按钮横向
 |  | ||||||
|         document.body.classList.remove('no-scroll'); // 允许滚动
 |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 阻止点击侧边栏时关闭侧边栏
 |  | ||||||
| sidebar.addEventListener('click', function(event) { |  | ||||||
|     event.stopPropagation();  // 阻止事件冒泡,防止点击侧边栏时关闭
 |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 动画效果
 |  | ||||||
| function animateToolCards() { |  | ||||||
|     const toolCards = document.querySelectorAll('.tool-card'); |  | ||||||
|     toolCards.forEach((card, index) => { |  | ||||||
|         card.style.transitionDelay = `${index * 100}ms`; // 按顺序延迟动画
 |  | ||||||
|         card.classList.add('animated'); // 添加动画类
 |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| ; |  | ||||||
| 
 |  | ||||||
| // 禁用双指缩放
 |  | ||||||
| document.addEventListener('touchstart', function(e) { |  | ||||||
|     if (e.touches.length > 1) {  // 如果检测到多于一个手指
 |  | ||||||
|         e.preventDefault();  // 阻止默认缩放行为
 |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| document.addEventListener('touchmove', function(e) { |  | ||||||
|     if (e.touches.length > 1) {  // 如果检测到多于一个手指
 |  | ||||||
|         e.preventDefault();  // 阻止默认缩放行为
 |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 获取搜索框输入和所有工具卡片
 |  | ||||||
| const searchInput = document.getElementById('search-input'); |  | ||||||
| const toolCards = document.querySelectorAll('.tool-card'); |  | ||||||
| 
 |  | ||||||
| // 监听搜索框的输入事件
 |  | ||||||
| searchInput.addEventListener('input', function() { |  | ||||||
|     const searchTerm = searchInput.value.toLowerCase().trim();  // 获取搜索关键词并转换为小写
 |  | ||||||
| 
 |  | ||||||
|     // 过滤工具卡片
 |  | ||||||
|     filterCards(searchTerm); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 过滤工具卡片
 |  | ||||||
| function filterCards(searchTerm) { |  | ||||||
|     const filteredCards = Array.from(toolCards).filter(card => { |  | ||||||
|         const title = card.querySelector('.tool-name').textContent.toLowerCase(); |  | ||||||
|         const description = card.querySelector('.card-description').textContent.toLowerCase(); |  | ||||||
|         return title.includes(searchTerm) || description.includes(searchTerm); |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     // 更新卡片布局
 |  | ||||||
|     updateCardLayout(filteredCards, searchTerm); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 更新卡片布局,确保卡片顺序正确
 |  | ||||||
| function updateCardLayout(filteredCards, searchTerm) { |  | ||||||
|     const container = document.querySelector('.tools-grid'); |  | ||||||
|     container.innerHTML = '';  // 清空容器中的所有卡片
 |  | ||||||
| 
 |  | ||||||
|     if (searchTerm === '') { |  | ||||||
|         // 如果搜索框为空,恢复原始顺序
 |  | ||||||
|         toolCards.forEach(card => container.appendChild(card)); |  | ||||||
|     } else { |  | ||||||
|         // 搜索时按顺序添加匹配的卡片
 |  | ||||||
|         filteredCards.forEach(card => container.appendChild(card)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // 确保跳转链接依然有效
 |  | ||||||
|     addLinkFunctionality(filteredCards); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 为每个卡片的链接添加跳转功能
 |  | ||||||
| function addLinkFunctionality(cards) { |  | ||||||
|     cards.forEach(card => { |  | ||||||
|         const link = card.querySelector('.tool-card-link');  // 获取卡片中的链接元素
 |  | ||||||
|         if (link) { |  | ||||||
|             // 确保链接点击时会跳转(无论是旧标签还是新标签)
 |  | ||||||
|             link.addEventListener('click', function(event) { |  | ||||||
|                 // 如果需要额外的功能(比如日志记录等),可以插入代码
 |  | ||||||
|                 // 例如:console.log('Tool clicked:', link.href);
 |  | ||||||
|                 // 无需手动修改 target="_blank",浏览器会根据 <a> 标签的设置自动处理
 |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 获取两个全屏按钮
 |  | ||||||
| const fullscreenButton = document.getElementById('fullscreen-button'); |  | ||||||
| const sidebarFullscreenButton = document.getElementById('sidebar-fullscreen-button'); |  | ||||||
| 
 |  | ||||||
| // 绑定全屏切换事件
 |  | ||||||
| function toggleFullscreen() { |  | ||||||
|     if (!document.fullscreenElement) { |  | ||||||
|         if (document.documentElement.requestFullscreen) { |  | ||||||
|             document.documentElement.requestFullscreen(); |  | ||||||
|         } else if (document.documentElement.mozRequestFullScreen) { |  | ||||||
|             document.documentElement.mozRequestFullScreen(); |  | ||||||
|         } else if (document.documentElement.webkitRequestFullscreen) { |  | ||||||
|             document.documentElement.webkitRequestFullscreen(); |  | ||||||
|         } else if (document.documentElement.msRequestFullscreen) { |  | ||||||
|             document.documentElement.msRequestFullscreen(); |  | ||||||
|         } |  | ||||||
|         updateFullscreenButton(true); |  | ||||||
|     } else { |  | ||||||
|         if (document.exitFullscreen) { |  | ||||||
|             document.exitFullscreen(); |  | ||||||
|         } else if (document.mozCancelFullScreen) { |  | ||||||
|             document.mozCancelFullScreen(); |  | ||||||
|         } else if (document.webkitExitFullscreen) { |  | ||||||
|             document.webkitExitFullscreen(); |  | ||||||
|         } else if (document.msExitFullscreen) { |  | ||||||
|             document.msExitFullscreen(); |  | ||||||
|         } |  | ||||||
|         updateFullscreenButton(false); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 更新按钮文本和图标
 |  | ||||||
| function updateFullscreenButton(isFullscreen) { |  | ||||||
|     const buttons = [fullscreenButton, sidebarFullscreenButton]; |  | ||||||
|     buttons.forEach(button => { |  | ||||||
|         if (isFullscreen) { |  | ||||||
|             button.querySelector('span').textContent = '退出'; |  | ||||||
|             button.querySelector('.icon').innerHTML = '↵'; // 退出全屏图标
 |  | ||||||
|         } else { |  | ||||||
|             button.querySelector('span').textContent = '全屏'; |  | ||||||
|             button.querySelector('.icon').innerHTML = '⛶'; // 全屏图标
 |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 绑定点击事件
 |  | ||||||
| fullscreenButton.addEventListener('click', toggleFullscreen); |  | ||||||
| sidebarFullscreenButton.addEventListener('click', toggleFullscreen); |  | ||||||
| 
 |  | ||||||
| // 页面加载完成后滚动到顶部
 |  | ||||||
| window.addEventListener('load', function() { |  | ||||||
|     setTimeout(function() { |  | ||||||
|         window.scrollTo(0, 0);  // 将页面滚动到顶部
 |  | ||||||
|     }, 100);  // 延迟 100ms 执行,确保页面已完全加载
 |  | ||||||
| }); |  | ||||||
							
								
								
									
										423
									
								
								styles.css
									
									
									
									
									
								
							
							
						
						
									
										423
									
								
								styles.css
									
									
									
									
									
								
							| @ -1,423 +0,0 @@ | |||||||
| /* 基本样式重置 */ |  | ||||||
| body, html { |  | ||||||
|     margin: 0; |  | ||||||
|     padding: 0; |  | ||||||
|     font-family: Arial, sans-serif; /* 设置页面的默认字体 */ |  | ||||||
|     background-color:#f4f4f4; |  | ||||||
| }  |  | ||||||
| 
 |  | ||||||
| /* 头部样式 */ |  | ||||||
| header { |  | ||||||
|     position: fixed; |  | ||||||
|     top: 0; |  | ||||||
|     left: 0; |  | ||||||
|     width: 100%; |  | ||||||
|     background-color: #ffffff; |  | ||||||
|     color: #fff; |  | ||||||
|     padding: 10px; |  | ||||||
|     display: flex; |  | ||||||
|     justify-content: space-between; |  | ||||||
|     align-items: center; |  | ||||||
|     z-index: 3000; |  | ||||||
|     transition: all 1s ease; /* 为头部的尺寸变化和样式变化添加过渡效果 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #search-input { |  | ||||||
|     height: 20px; |  | ||||||
|     width: 500px; |  | ||||||
|     display: inline-block; |  | ||||||
|     border: 1px solid #ccc; |  | ||||||
|     border-radius: 20px; |  | ||||||
|     padding: 5px 15px; |  | ||||||
|     transition: width 0.3s ease, padding 0.3s ease, top 0.3s ease; /* 加入 top 过渡效果 */ |  | ||||||
|     outline: none; |  | ||||||
|     background-color: #fff; |  | ||||||
|     text-align: center; |  | ||||||
|     margin-bottom: 20px; |  | ||||||
|     position: fixed; /* 固定定位 */ |  | ||||||
|     top: 10px; /* 初始位置距离顶部20px */ |  | ||||||
|     left: 50%; |  | ||||||
|     transform: translateX(-50%); /* 居中显示 */ |  | ||||||
|     z-index: 1000; /* 确保在顶部 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 鼠标悬停时搜索框展开 */ |  | ||||||
| #search-input:hover, |  | ||||||
| #search-input:focus { |  | ||||||
|     width: 600px; /* 展开宽度 */ |  | ||||||
|     padding: 5px 20px; /* 调整内边距 */ |  | ||||||
|     box-shadow: 0 0 5px rgba(0, 0, 0, 0.2); /* 添加阴影效果 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /* 按钮的基础样式 */ |  | ||||||
| header .toggle-menu { |  | ||||||
|     display: inline-block; |  | ||||||
|     font-size: 24px; |  | ||||||
|     background: none; |  | ||||||
|     border: none; |  | ||||||
|     color: rgb(235, 10, 10); |  | ||||||
|     cursor: pointer; |  | ||||||
|     margin-right: 20px;  /* 设置右边距 */ |  | ||||||
|     transition: transform 0.3s ease-in-out;  /* 添加平滑过渡效果 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 悬停效果,按钮背景颜色变化 */ |  | ||||||
| header .toggle-menu:hover { |  | ||||||
|     background-color: rgba(235, 10, 10, 0.1);  /* 增加轻微的背景色变化 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 头部全屏按钮样式(仅大屏幕显示) */ |  | ||||||
| #fullscreen-button { |  | ||||||
|     position: absolute; |  | ||||||
|     right: 16px; |  | ||||||
|     top: 0px; |  | ||||||
|     background: none; |  | ||||||
|     border: none; |  | ||||||
|     cursor: pointer; |  | ||||||
|     font-size: 32px; |  | ||||||
|     display: flex; |  | ||||||
|     align-items: center; |  | ||||||
|     transition: top 0.3s ease,transform 0.3s ease-in-out, padding 0.3s ease-in-out; /* 平滑放大动画 */ |  | ||||||
|     transform-origin: center center; /* 确保放大时的中心不变 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #fullscreen-button:hover { |  | ||||||
|     transform: scale(1.20); /* 悬停时上下左右均匀放大 5% */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 侧边栏 */ |  | ||||||
| .sidebar { |  | ||||||
|     position: fixed; |  | ||||||
|     top: -30px; |  | ||||||
|     left: 0; |  | ||||||
|     width: 250px; |  | ||||||
|     bottom: 24px; |  | ||||||
|     background-color: #f4f4f4; |  | ||||||
|     color: rgb(100, 99, 99); /* logo颜色 */ |  | ||||||
|     display: flex; |  | ||||||
|     flex-direction: column; |  | ||||||
|     align-items: center;  /* 水平居中 */ |  | ||||||
|     padding: 20px; |  | ||||||
|     transition: transform 0.3s ease-in-out; |  | ||||||
|     z-index: 2000; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 使用 @font-face 引用本地字体 */ |  | ||||||
| @font-face { |  | ||||||
|     font-family: 'Pacifico'; /* 字体名称 */ |  | ||||||
|     src: url('font/Pacifico.ttf') format('truetype'); /* 设置 .ttf 格式 */ |  | ||||||
|     font-weight: normal; |  | ||||||
|     font-style: normal; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .logo { |  | ||||||
|     font-family: 'Pacifico', cursive; /* 使用本地字体 Pacifico */ |  | ||||||
|     margin: 0; |  | ||||||
|     padding-top: 48px; |  | ||||||
|     text-align: center; /* 确保整个 logo 居中 */ |  | ||||||
|     display: flex; |  | ||||||
|     flex-direction: column; /* 将 part1 和 part2 垂直排列 */ |  | ||||||
|     align-items: center; /* 确保每个部分居中 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .logo .part1 { |  | ||||||
|     font-size: 50px; /* "ream" 字体较大 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .logo .part2 { |  | ||||||
|     font-size: 40px; /* ".life" 字体较小 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 侧边栏链接的基础样式 */ |  | ||||||
| .sidebar-link { |  | ||||||
|     position: relative; |  | ||||||
|     font-size: 22px; |  | ||||||
|     font-weight: bold; |  | ||||||
|     margin-top: 48px; |  | ||||||
|     color: rgb(117, 115, 115); |  | ||||||
|     text-decoration: none;  /* 去掉默认的下划线 */ |  | ||||||
|     display: inline-block; |  | ||||||
|     padding: 10px 20px; |  | ||||||
|     background-color: #f4f4f4; |  | ||||||
|     transition: all 0.3s ease;  /* 添加平滑过渡效果 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 侧边栏链接内容的容器 */ |  | ||||||
| .sidebar-link .link-content { |  | ||||||
|     display: flex; |  | ||||||
|     background-color: #f4f4f4; |  | ||||||
|     align-items: center;  /* 确保文字和图标垂直居中 */ |  | ||||||
|     transition: transform 0.3s ease;  /* 添加平滑过渡 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 悬停时图标和文字一起上浮 */ |  | ||||||
| .sidebar-link:hover .link-content { |  | ||||||
|     transform: translateY(-3px);  /* 向上浮起5px */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 图标样式 */ |  | ||||||
| .sidebar-link .icon { |  | ||||||
|     margin-right: 10px; /* 给图标和文字之间留点空隙 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 悬停时改变链接的颜色 */ |  | ||||||
| .sidebar-link:hover { |  | ||||||
|     color: #000; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 按钮文本和图标的状态样式 */ |  | ||||||
| .sidebar-link.fullscreen .icon { |  | ||||||
|     transform: rotate(90deg);  /* 图标旋转 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 退出全屏时的样式 */ |  | ||||||
| .sidebar-link.fullscreen span { |  | ||||||
|     content: "退出全屏";  /* 修改文本为"退出全屏" */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /* 禁用页面滚动样式 */ |  | ||||||
| body.no-scroll { |  | ||||||
|     overflow: hidden;  /* 禁止页面滚动 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 主内容区 */ |  | ||||||
| .main-content { |  | ||||||
|     margin-left: 270px; |  | ||||||
|     margin-right: 20px; |  | ||||||
|     margin-top: 14px; /* 增加主内容区的上边距 */ |  | ||||||
|     padding: 20px; |  | ||||||
|     display: flex; |  | ||||||
|     flex-direction: column; |  | ||||||
|     justify-content: space-between; |  | ||||||
|     z-index: 1;  /* 确保内容在侧边栏下方 */ |  | ||||||
|     position: relative;  /* 确保相对定位 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .sidebar { |  | ||||||
|     flex: 1 1 250px; /* 允许侧边栏在可用空间内缩放 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .content { |  | ||||||
|     flex: 3 1 600px; /* 允许内容区域在可用空间内缩放 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 为整个工具卡片添加链接样式 */ |  | ||||||
| .tool-card-link { |  | ||||||
|     text-decoration: none; /* 去掉链接的下划线 */ |  | ||||||
| } |  | ||||||
| /* 保证工具卡片正常排列 */ |  | ||||||
| .tools-grid { |  | ||||||
|     display: grid; |  | ||||||
|     grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); |  | ||||||
|     gap: 20px; |  | ||||||
|     padding: 20px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 保证工具卡片的顺序 */ |  | ||||||
| .tool-card { |  | ||||||
|     display: flex; |  | ||||||
|     flex-direction: column; /* 使 logo 在上,名称在下 */ |  | ||||||
|     align-items: flex-start; /* 左对齐 */ |  | ||||||
|     background: white; |  | ||||||
|     border-radius: 8px; |  | ||||||
|     box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); |  | ||||||
|     padding: 20px; |  | ||||||
|     text-align: left; /* 左对齐 */ |  | ||||||
|     min-height: 180px; |  | ||||||
|     transition: transform 0.5s ease, box-shadow 0.5s ease; /* 工具卡片动画时间设置为 0.5s */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 工具卡片动画完成状态 */ |  | ||||||
| .tool-card.animated { |  | ||||||
|     opacity: 1; |  | ||||||
|     transform: translateY(0); /* 恢复到正常位置 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 工具卡片悬停效果 */ |  | ||||||
| .tool-card:hover { |  | ||||||
|     transform: scale(1.03); |  | ||||||
|     box-shadow: 0 8px 15px rgba(0, 0, 0, 0.2); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 工具卡片logo样式 */ |  | ||||||
| .tool-logo { |  | ||||||
|     margin-left: 30px; |  | ||||||
|     margin-top: 10px; |  | ||||||
|     width: 50px;  /* 设置logo的宽度 */ |  | ||||||
|     height: 50px; |  | ||||||
|     margin-bottom: 10px;  /* 给logo和名称之间留出间距 */ |  | ||||||
|     border-radius: 8px;  /* 设置圆角矩形 */ |  | ||||||
|     object-fit: cover; /* 保证图片不会被拉伸或变形 */ |  | ||||||
|     display:block; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 工具名称的样式 */ |  | ||||||
| .tool-name { |  | ||||||
|     margin-left: 30px; |  | ||||||
|     margin-top: 10px; |  | ||||||
|     font-size: 20px; |  | ||||||
|     font-weight: bold; |  | ||||||
|     color: #333; |  | ||||||
|     text-decoration: none; |  | ||||||
|     position: relative; /* 使下划线定位相对 */ |  | ||||||
|     display: inline-block; /* 确保工具名称独占一行 */ |  | ||||||
|     text-align: left; /* 左对齐 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 工具名称的下划线效果 */ |  | ||||||
| .tool-name::after { |  | ||||||
|     content: ""; |  | ||||||
|     position: absolute; |  | ||||||
|     bottom: -5px; |  | ||||||
|     left: 0; |  | ||||||
|     width: 0; |  | ||||||
|     height: 2px; |  | ||||||
|     background-color: black; |  | ||||||
|     transition: width 0.3s ease; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .tool-name:hover::after { |  | ||||||
|     width: 100%;  /* 让下划线横跨整个文字 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 分类标签样式 */ |  | ||||||
| .tool-category { |  | ||||||
|     display: inline-block; /* 使标签处于同一行 */ |  | ||||||
|     padding: 4px 16px; /* 胶囊形状的内边距,横向较宽 */ |  | ||||||
|     background-color: #fc8f8f; /* 背景颜色 */ |  | ||||||
|     color: #ffffff; /* 文字颜色 */ |  | ||||||
|     font-size: 10px; /* 字体大小 */ |  | ||||||
|     font-weight: bold; /* 加粗字体 */ |  | ||||||
|     border-radius: 50px; /* 设置圆角,形成胶囊形状 */ |  | ||||||
|     margin-left: 30px; |  | ||||||
|     margin-top: 10px; /* 给标签和描述之间留出间距 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 工具描述样式 */ |  | ||||||
| .card-description { |  | ||||||
|     font-size: 14px; |  | ||||||
|     color: #777; |  | ||||||
|     margin-left: 30px; |  | ||||||
|     margin-top: 10px;  /* 给描述添加上边距 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 悬停效果 */ |  | ||||||
| .tool-card:hover { |  | ||||||
|     transform: scale(1.03); |  | ||||||
|     box-shadow: 0 8px 15px rgba(0, 0, 0, 0.2); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 页脚样式 - 默认 (电脑设备) */ |  | ||||||
| footer { |  | ||||||
|     background-color: rgba(51, 51, 51, 0.5); /* 半透明背景 */ |  | ||||||
|     color: white; |  | ||||||
|     display: flex;  /* 使用 flex 布局 */ |  | ||||||
|     justify-content: center;  /* 水平居中 */ |  | ||||||
|     align-items: center;  /* 垂直居中 */ |  | ||||||
|     padding: 0px; |  | ||||||
|     position: fixed; |  | ||||||
|     left: 0; |  | ||||||
|     right: 0; |  | ||||||
|     bottom: 0; |  | ||||||
|     font-size: 14px; |  | ||||||
|     max-height: 30px; |  | ||||||
|     z-index: 2000;  /* 提升侧边栏的层级 */ |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* 响应式设计 */ |  | ||||||
| @media (max-width: 768px) { |  | ||||||
|     #fullscreen-button { |  | ||||||
|         display: none; /* 小屏幕隐藏头部全屏按钮 */ |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     #sidebar-fullscreen-button { |  | ||||||
|         display: flex; /* 小屏幕显示侧边栏全屏按钮 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     #search-input { |  | ||||||
|         width: 50%; /* 设置宽度为屏幕的50% */ |  | ||||||
|         padding: 5px 15px; |  | ||||||
|         top: 10px; |  | ||||||
|         left: 50%; /* 使搜索框居中 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     #search-input:hover, |  | ||||||
|     #search-input:focus { |  | ||||||
|         width: 60%; /* 展开宽度 */ |  | ||||||
|         padding: 5px 20px; /* 调整内边距 */ |  | ||||||
|         box-shadow: 0 0 5px rgba(0, 0, 0, 0.2); /* 添加阴影效果 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /* 小屏幕时侧边栏 */ |  | ||||||
|     .sidebar { |  | ||||||
|         width: 80%;  /* 设置侧边栏宽度为60% */ |  | ||||||
|         bottom: 0; |  | ||||||
|         transform: translateX(-100%);  /* 默认隐藏侧边栏 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     .sidebar.open { |  | ||||||
|         transform: translateX(0); |  | ||||||
|         bottom: 0; |  | ||||||
|         width: 80%;  /* 确保侧边栏在打开时宽度为60% */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /* 小屏幕时主内容区 */ |  | ||||||
|     .main-content { |  | ||||||
|         margin-left:  0px;  /* 小屏幕时移除左边距 */ |  | ||||||
|         margin-right: 0px;  /* 小屏幕时右边距减小 */ |  | ||||||
|         margin-top: 60px;  /* 小屏幕时稍微减小上边距 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /* 小屏幕时头部 */ |  | ||||||
|     header { |  | ||||||
|         height: 40px;  /* 设置头部高度为50px */ |  | ||||||
|         justify-content: space-between; /* 保持头部内容在两端 */ |  | ||||||
|         align-items: center; /* 垂直居中内容 */ |  | ||||||
|     } |  | ||||||
|     /* 小屏幕时菜单按钮 */ |  | ||||||
|     header .toggle-menu { |  | ||||||
|         display: block;  /* 在小屏幕时显示菜单按钮 */ |  | ||||||
|         font-size: 24px; |  | ||||||
|         background: none; |  | ||||||
|         border: none; |  | ||||||
|         color: rgb(235, 10, 10); |  | ||||||
|         cursor: pointer; |  | ||||||
|         position: absolute; |  | ||||||
|         top: 10px; /* 距离顶部20px */ |  | ||||||
|         right: 14px; /* 距离右侧20px */ |  | ||||||
|         transition: transform 0.3s ease-in-out;  /* 添加平滑过渡效果 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /* 悬停效果,按钮背景颜色变化 */ |  | ||||||
|     header .toggle-menu:hover { |  | ||||||
|         background-color: rgba(235, 10, 10, 0.1);  /* 增加轻微的背景色变化 */ |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| @media (min-width: 768px) { |  | ||||||
|     header { |  | ||||||
|         background: none; /* 去掉头部背景色 */ |  | ||||||
|         box-shadow: none; /* 去掉头部阴影 */ |  | ||||||
|         height: auto; /* 自动高度适应搜索框 */ |  | ||||||
|         padding: 0; /* 去掉多余的内边距 */ |  | ||||||
|         top: 10px; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     #fullscreen-button { |  | ||||||
|         display: flex; /* 小屏幕隐藏头部全屏按钮 */ |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     #sidebar-fullscreen-button { |  | ||||||
|         display: none; /* 小屏幕显示侧边栏全屏按钮 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     #search-input { |  | ||||||
|         margin: 0 auto; /* 搜索框居中显示 */ |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     header .toggle-menu { |  | ||||||
|         display: none;  /* 在小屏幕时显示菜单按钮 */ |  | ||||||
|     } |  | ||||||
| } |  | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user