项目介绍:主要将学习到的项目内容进行总结(有需要项目源码的可以私信我)
关于我的项目的配置如下,请注意下载的每个版本不一样,写的api也不一样
1)短信接收&M端演示:极客园http://geek.itheima.net
2)PC端接口文档:极客园PChttp://geek.itheima.net/api-pc.html
1)【极客园】对标CSDN、博客园等竞品,致力成为更加贴近年轻IT从业者(学员)的科技资讯类应用
2)产品关键词:IT、极客、活力、科技、技术分享、前沿动态、内容社交
3)产品用户特点:年轻有活力,对IT领域前沿科技信息充满探索欲和学习热情
4)极客园PC端项目:个人自媒体管理端
5)项目演示
6)项目功能
1)安装路由:yarn add react-router-dom
使用yarn add的时候可能会报上述错误,报的话可以使用npm install react-router-dom来进行安装
2)在pages目录中创建两个页面:Login(登录页面)、Layout(首页)
3)在App.js中配置路由
import React from 'react'
import { BrowserRouter as Router, Route, Link, Routes } from 'react-router-dom'
import Login from './pages/Login'
import Layout from './pages/Layout'
function App() {
return (
{/* 登录
首页 */}
{/* 配置路由的规则 */}
}>
{/* }> */}
}>
)
}
export default App
配置完路由就可以实现,网页输入网址,展示对应的页面的内容
此时需要注意的点是:
a.老版本用component = {
b:旧版本使用Switchl来添加多个路由,新版本使用Routes
1)官方文档链接
Ant Design - 一套企业级 UI 设计语言和 React 组件库
2)antd是基于Ant Design设计体系的React UI组件库,主要用于研发企业级中后台产品
3)开箱即用
a.安装:npm install antd
b.使用
import { Button, DatePicker, Card } from 'antd'
// 导入antd的全局样式
import 'antd/dist/reset.css'
功能如下:
export default class Login extends Component {
render() {
return (
{/* 登陆组件 */}
{/* */}
{/* */}
{/* More} style={{ width: 300 }}> */}
{/* Card content
Card content
Card content
*/}
)
}
}
.login {
width: 100vw;
height: 100vh;
background-image: url('../../assets/login.png');
position: relative;
}
.login-container {
width: 440px;
height: 360px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.login-logo {
width: 200px;
height: 40px;
display: block;
margin: 0 auto 20px;
}
我们使用相对路径../导入图片可能存在文件位置移动找不到图片的效果,所以使用绝对路径来配置
Importing a Component | Create React App
1)在项目根目录下创建jsconfig.json文件
{
"compilerOptions": {
"baseUrl": "src"
},
"include": ["src"]
}
2)导入删除掉相对路径
import logo from 'assets/logo.png'
1)安装sass
2)将css文件后缀改为.sass
3)使用sass以后就可以实现样式包裹,但是里面如果使用绝对路径会进行报错,所以需要使用~来进行导入
.login {
width: 100vw;
height: 100vh;
background-image: url('~assets/login.png');
position: relative;
.login-container {
width: 440px;
height: 360px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.login-logo {
width: 200px;
height: 40px;
display: block;
margin: 0 auto 20px;
}
}
5.