刚创建 React 项目时,那个带着旋转 Logo 的默认页面相信大家都不陌生。看似简单的效果背后,藏着 HTML、CSS 和 JavaScript 的巧妙配合。今天就带大家深入挖掘每个代码细节,看看这个经典页面是如何实现的。
从 JSX 结构看 HTML 布局逻辑
在 App.js 文件中,虽然使用的是 React 特有的 JSX 语法,但本质上构建的是类似 HTML 的页面结构。先看资源导入部分:
import logo from './logo.svg';
import './App.css';
1. import logo from './logo.svg';
这行代码通过 ES6 模块导入方式,将项目中名为 logo.svg 的矢量图资源引入到组件中。SVG 格式相比传统图片格式,在缩放时不会失真,非常适合作为图标展示。
2. import './App.css';
则是将样式文件引入,后续组件的样式都依赖这个文件来实现。
再看 App 组件返回的 JSX 内容:
function App() {
return (
<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.js</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
</header>
</div>
);
}
最外层的 <div className="App">
相当于整个页面的容器,通过添加 App 类名,后续可以在 CSS 中针对性地设置样式。
<header className="App-header">
标签定义了页面的头部区域,所有头部相关的内容都包裹在里面。
<img src={logo} className="App-logo" alt="logo" />
这行代码将之前导入的 logo 图片渲染到页面上,className 为 App-logo 方便后续设置样式,alt 属性则是为了在图片无法加载时显示替代文本,提高页面的可访问性。
<p> 标签内的提示文字 Edit <code>src/App.js</code> and save to reload.
用 <code>
标签包裹文件名,是为了在视觉上呈现代码文本的样式,提示开发者修改 App.js 文件就能触发页面重新加载。
⭐⭐⭐超链接细节
最后的 <a>
标签创建了一个超链接,href="<https://reactjs.org>
" 指定了链接跳转地址,target="_blank"
表示在新窗口打开链接,rel="noopener noreferrer"
则是出于安全考虑,防止新窗口通过 window.opener
访问原窗口,避免潜在的安全风险。
CSS 样式:从布局到动画的细节把控
页面整体布局
.App {
text-align: center;
}
.App 类选择器选中页面最外层的容器元素,text-align: center;
让容器内的所有行内元素(如文本、内联图片等)水平居中,保证页面内容视觉上的整齐。
Logo 样式细节
.App-logo {
height: 40vmin;
pointer-events: none;
}
为何要使用vmin
height: 40vmin;
使用 vmin 作为单位,vmin 是相对于视口较小尺寸的长度单位。比如在一个宽 800px、高 600px 的视口中,1vmin 等于 6px(取宽和高中较小的值 600px,计算 600 / 100 = 6)。使用 vmin 单位设置 Logo 高度,能让 Logo 在不同尺寸屏幕上保持相对合适的大小,实现响应式布局。
pointer-events: none;
则是让 Logo 图片忽略鼠标事件,比如点击、悬停等操作都不会触发任何效果。这是因为在默认页面中,Logo 只是装饰性元素,不需要交互,这样设置可以避免用户误操作带来的困扰。
动画效果实现
@media (prefers-reduced-motion: no-preference) {
.App-logo {
animation: App-logo-spin infinite 20s linear;
}
}
@keyframes App-logo-spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
@media (prefers-reduced-motion: no-preference)
是一个媒体查询,它会检测用户系统是否设置了 “减少动画” 的偏好。如果用户没有设置这个偏好(即 no-preference),则会应用内部的样式。这一设计是为了照顾到那些不希望看到过多动画效果的用户,比如对动画敏感或者设备性能有限的用户,体现了网页设计的用户体验优化。
windows操作系统如下
animation: App-logo-spin infinite 20s linear;
这行代码为 App-logo 元素添加了动画效果。App-logo-spin
是自定义的动画名称,对应下面定义的 @keyframes
规则;infinite
表示动画无限循环播放;20s
是动画完成一次循环的持续时间;linear
表示动画在整个过程中以匀速进行,不会出现加速或减速的情况。
动画效果的关键
@keyframes App-logo-spin
定义了动画的关键帧。from
表示动画起始状态,transform: rotate(0deg);
让 Logo 初始角度为 0 度;to
表示动画结束状态,transform: rotate(360deg);
让 Logo 旋转到 360 度,通过这两个关键帧,实现了 Logo 从 0 度到 360 度的旋转效果。
头部样式设置
.App-header {
background-color: #282c34;
min-height: 100vh;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
font-size: calc(10px + 2vmin);
color: white;
}
background-color: #282c34;
设置头部的背景颜色为深灰色,与白色文字形成对比,提高可读性。min-height: 100vh;
让头部区域至少占据整个视口的高度,保证页面内容能完全展示在用户视野内。
display: flex;
开启 Flexbox 布局,flex-direction: column; 将子元素垂直排列。align-items: center; 和 justify-content: center; 分别在交叉轴和主轴上对子元素进行居中对齐,确保头部内的所有内容(Logo、文字、链接)都能在页面中间显示。
font-size: calc(10px + 2vmin);
使用 calc 函数动态计算字体大小,结合固定的 10px 和随视口变化的 2vmin,实现字体大小的响应式调整。color: white; 则是设置头部文字的颜色。
链接样式
.App-link {
color: #61dafb;
}
.App-link 类选择器选中页面中的超链接元素,color: #61dafb; 将链接颜色设置为明亮的天蓝色,与页面整体的深色调形成鲜明对比,吸引用户注意力,同时也呼应了 React 官方的品牌配色。
JavaScript 与 React 的配合
在这个默认页面中,JavaScript 代码主要用于通过 React 框架定义组件。App 函数组件返回的 JSX 结构,最终会被 React 渲染成真实的 DOM 元素展示在页面上。虽然这里没有复杂的 JavaScript 逻辑,但 React 在背后完成了组件的创建、更新和渲染等一系列工作,保证页面能够正确显示,并在后续开发中支持动态更新和交互。
结语
通过对 React 默认视图页面的代码拆解,我们看到了 HTML、CSS 和 JavaScript 如何各司其职,共同打造出这个经典的页面效果。从响应式布局的实现到动画效果的细节优化,从超链接的安全设置到用户体验的考量,每个代码片段都蕴含着开发者的巧思。理解这些基础实现,能为我们后续的 React 项目开发打下坚实的基础,也能让我们在构建页面时更注重细节,打造出更好的用户体验。
从 JSX 结构看 HTML 布局逻辑
在 App.js 文件中,虽然使用的是 React 特有的 JSX 语法,但本质上构建的是类似 HTML 的页面结构。先看资源导入部分:
import logo from './logo.svg';
import './App.css';
1. import logo from './logo.svg';
这行代码通过 ES6 模块导入方式,将项目中名为 logo.svg 的矢量图资源引入到组件中。SVG 格式相比传统图片格式,在缩放时不会失真,非常适合作为图标展示。
2. import './App.css';
则是将样式文件引入,后续组件的样式都依赖这个文件来实现。
再看 App 组件返回的 JSX 内容:
function App() {
return (
<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.js</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
</header>
</div>
);
}
最外层的 <div className="App">
相当于整个页面的容器,通过添加 App 类名,后续可以在 CSS 中针对性地设置样式。
<header className="App-header">
标签定义了页面的头部区域,所有头部相关的内容都包裹在里面。
<img src={logo} className="App-logo" alt="logo" />
这行代码将之前导入的 logo 图片渲染到页面上,className 为 App-logo 方便后续设置样式,alt 属性则是为了在图片无法加载时显示替代文本,提高页面的可访问性。
<p> 标签内的提示文字 Edit <code>src/App.js</code> and save to reload.
用 <code>
标签包裹文件名,是为了在视觉上呈现代码文本的样式,提示开发者修改 App.js 文件就能触发页面重新加载。
⭐⭐⭐超链接细节
最后的 <a>
标签创建了一个超链接,href="<https://reactjs.org>
" 指定了链接跳转地址,target="_blank"
表示在新窗口打开链接,rel="noopener noreferrer"
则是出于安全考虑,防止新窗口通过 window.opener
访问原窗口,避免潜在的安全风险。
CSS 样式:从布局到动画的细节把控
页面整体布局
.App {
text-align: center;
}
.App 类选择器选中页面最外层的容器元素,text-align: center;
让容器内的所有行内元素(如文本、内联图片等)水平居中,保证页面内容视觉上的整齐。
Logo 样式细节
.App-logo {
height: 40vmin;
pointer-events: none;
}
为何要使用vmin
height: 40vmin;
使用 vmin 作为单位,vmin 是相对于视口较小尺寸的长度单位。比如在一个宽 800px、高 600px 的视口中,1vmin 等于 6px(取宽和高中较小的值 600px,计算 600 / 100 = 6)。使用 vmin 单位设置 Logo 高度,能让 Logo 在不同尺寸屏幕上保持相对合适的大小,实现响应式布局。
pointer-events: none;
则是让 Logo 图片忽略鼠标事件,比如点击、悬停等操作都不会触发任何效果。这是因为在默认页面中,Logo 只是装饰性元素,不需要交互,这样设置可以避免用户误操作带来的困扰。
动画效果实现
@media (prefers-reduced-motion: no-preference) {
.App-logo {
animation: App-logo-spin infinite 20s linear;
}
}
@keyframes App-logo-spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
@media (prefers-reduced-motion: no-preference)
是一个媒体查询,它会检测用户系统是否设置了 “减少动画” 的偏好。如果用户没有设置这个偏好(即 no-preference),则会应用内部的样式。这一设计是为了照顾到那些不希望看到过多动画效果的用户,比如对动画敏感或者设备性能有限的用户,体现了网页设计的用户体验优化。
windows操作系统如下
animation: App-logo-spin infinite 20s linear;
这行代码为 App-logo 元素添加了动画效果。App-logo-spin
是自定义的动画名称,对应下面定义的 @keyframes
规则;infinite
表示动画无限循环播放;20s
是动画完成一次循环的持续时间;linear
表示动画在整个过程中以匀速进行,不会出现加速或减速的情况。
动画效果的关键
@keyframes App-logo-spin
定义了动画的关键帧。from
表示动画起始状态,transform: rotate(0deg);
让 Logo 初始角度为 0 度;to
表示动画结束状态,transform: rotate(360deg);
让 Logo 旋转到 360 度,通过这两个关键帧,实现了 Logo 从 0 度到 360 度的旋转效果。
头部样式设置
.App-header {
background-color: #282c34;
min-height: 100vh;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
font-size: calc(10px + 2vmin);
color: white;
}
background-color: #282c34;
设置头部的背景颜色为深灰色,与白色文字形成对比,提高可读性。min-height: 100vh;
让头部区域至少占据整个视口的高度,保证页面内容能完全展示在用户视野内。
display: flex;
开启 Flexbox 布局,flex-direction: column; 将子元素垂直排列。align-items: center; 和 justify-content: center; 分别在交叉轴和主轴上对子元素进行居中对齐,确保头部内的所有内容(Logo、文字、链接)都能在页面中间显示。
font-size: calc(10px + 2vmin);
使用 calc 函数动态计算字体大小,结合固定的 10px 和随视口变化的 2vmin,实现字体大小的响应式调整。color: white; 则是设置头部文字的颜色。
链接样式
.App-link {
color: #61dafb;
}
.App-link 类选择器选中页面中的超链接元素,color: #61dafb; 将链接颜色设置为明亮的天蓝色,与页面整体的深色调形成鲜明对比,吸引用户注意力,同时也呼应了 React 官方的品牌配色。
JavaScript 与 React 的配合
在这个默认页面中,JavaScript 代码主要用于通过 React 框架定义组件。App 函数组件返回的 JSX 结构,最终会被 React 渲染成真实的 DOM 元素展示在页面上。虽然这里没有复杂的 JavaScript 逻辑,但 React 在背后完成了组件的创建、更新和渲染等一系列工作,保证页面能够正确显示,并在后续开发中支持动态更新和交互。
结语
通过对 React 默认视图页面的代码拆解,我们看到了 HTML、CSS 和 JavaScript 如何各司其职,共同打造出这个经典的页面效果。从响应式布局的实现到动画效果的细节优化,从超链接的安全设置到用户体验的考量,每个代码片段都蕴含着开发者的巧思。理解这些基础实现,能为我们后续的 React 项目开发打下坚实的基础,也能让我们在构建页面时更注重细节,打造出更好的用户体验。