react实战——react旅游网

news/2024/7/15 19:01:49 标签: react.js, 前端, 前端框架

慕课网react实战

  • 搭建项目
  • 问题
    • 1.按照官网在index.tsx中引入antd出错?
    • 2.typescript中如何使用react-router
    • 3.react-router
      • 3.1 V6
      • 3.2 V5
      • 3.3V6实现私有路由
    • 4.函数式组件接收props参数时定义数据接口?
    • 5.使用TypeScript开发react项目:
    • 6.要使一个组件拥有路由组件的history、location、match等属性
    • 7.书写代码规范上的一些问题
    • 8.使用redux和react-redux
      • 8.1使用react-redux
      • 8.2类式组件中使用react-redux
      • 8.3函数式组件中使用react-redux(使用hooks函数)
      • 8.4使用redux
      • 8.5异步处理redux-thunk——可以在action中处理异步任务
      • 8.6自定义中间件
      • 8.7redux-tooltik
    • 9.I18n网站国际化
    • 10.获得全局数据的两种方式?
      • 10.1 在类组件中使用高阶函数
      • 10.2在函数式组件中使用hooks
    • 11.如何处理请求得到的html字符串为网页
    • 12.登录相关
      • 12.1单点登录与JWT
    • 13报错
  • 网络请求
    • axios
    • 对悬空数据做预处理!!!!!
    • 避免在useEffect中一直请求网络数据

搭建项目

创建基于typescript的react项目:create-react-app react-travel --template typescript
安装依赖:npm install typescript-plugin-css-modules --save-dev

问题

1.按照官网在index.tsx中引入antd出错?

出错时因为路径问题:官网中是:import 'antd/dist/antd.css';,但是在依赖目录中没有antd.css文件,只有reset.css,所以改变路径即可:
import 'antd/dist/reset.css';

2.typescript中如何使用react-router

  1. react-router并没有提供原生typescript的支持,所以我们需要安装react-router的类型定义,
    npm install --save-dev @types/react-router-dom
    typescript的支持我们只在开发过程中使用,所以安装的开发依赖中-dev(结余上线后的体积)
  2. 怎么样我们才能知道一个框架有没有原生的支持typescript呢:
    -上网搜
    -直接使用,没有出现类型的提示警告之类的,就是支持的。

3.react-router

3.1 V6

在这里插入图片描述
<Route path="*" element={<p>There's nothing here: 404!</p>} />

3.2 V5

函数式组件中使用
在这里插入图片描述

3.3V6实现私有路由

在这里插入图片描述
在这里插入图片描述
解决方案:
在v6中,您应该将组件作为“元素”传递,例如像这样:
<Route path="/" element={<Dashboard/>}>
在这里插入图片描述

4.函数式组件接收props参数时定义数据接口?

在利用typescript编写react项目时,函数式组件需要定义返回值类型。传递的props参数的类型,就是使用interface泛型定义的

5.使用TypeScript开发react项目:

  1. 函数式组件写法有区别与js的,区别就是函数式组件需要写成箭头函数,传递props参数时需要指定类型,interface泛型。
  2. 什么时候使用ReactComponentProps
    在这里插入图片描述
  3. 使用redux时需要做的处理

6.要使一个组件拥有路由组件的history、location、match等属性

  1. 需要使用withRouter将组件包裹起来(reactrouter6以下版本),还可以使用useHistory、useLocation、useParams、useRouteMatch(函数式组件中)
  2. reactRouter6需要使用hooks钩子,useXxxx,钩子只能在函数式组件中使用
    要在类式组件中使用的话,可以使用高阶组件,对类组件进行一个包裹,让原始类组件拥有useNavigate功能

7.书写代码规范上的一些问题

1. 函数式组件中元素调用方法时加不加括号,写不写this,什么时候用箭头函数
2.reducer中赋新值时的解构
3. 什么是高阶组件

8.使用redux和react-redux

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

8.1使用react-redux

npm i react-redux,它并不原生支持typescript,需要再安装npm install @types/react-redux --save-dev

8.2类式组件中使用react-redux

就是笔记中那样,导入connect包裹连接UI组件和容器组件

8.3函数式组件中使用react-redux(使用hooks函数)

使用钩子函数useSelector(解决组件和store的耦合问题),可以连接store
使用钩子函数useDispatch()分发dispatch
使用完以上两个钩子函数后就可以直接连接起状态数据和action了,不需要再导入store
Header组件

8.4使用redux

类式组件和函数式组件都一样,在需要使用数据的地方,引入store,使用store.getStore()获取数据,使用store.dispatch()分发动作
HomePage组件

8.5异步处理redux-thunk——可以在action中处理异步任务

8.6自定义中间件

在这里插入图片描述

8.7redux-tooltik

redux-tooltik.js.org
以下是编写状态管理
在这里插入图片描述
在这里插入图片描述

createSlice:action与reducer捆绑在一起了
将detail从MVC修改到redux-tooltik
以下是编写异步数据操作
在这里插入图片描述
在这里插入图片描述

9.I18n网站国际化

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
这两个框架本身就都支持原生typescript,不需要再额外安装对typescript的类型声明文件

10.获得全局数据的两种方式?

10.1 在类组件中使用高阶函数

10.2在函数式组件中使用hooks

11.如何处理请求得到的html字符串为网页

要通过特定的API渲染

12.登录相关

12.1单点登录与JWT

JWT是干什么的
官网:jwt.io
全称为JSON Web Token,JWT的作用是用户授权,而不是用户的身份认证。
用户授权
用户授指当前用户有足够的权限访问特定的资源(错误状态码:403forbidden禁止访问)
用户认证
用户认证指的是使用用户名、密码来验证当前用户的身份(就是用户登录,错误状态码401Unauthorized未授权)
在这里插入图片描述
在这里插入图片描述

解码jwt
npm i jwt-decode
npm i jwt-decode @types/jwt-decode --save const token = jwtDecode(jwt);
登录持久化
npm install redux-persist
需要做的操作:
在这里插入图片描述
在这里插入图片描述

13报错

在这里插入图片描述

interface MyComponentProps extends RouteComponentProps {  
touristRouteId: string;
}
const MyComponent: React.FC<MyComponentProps> = ({ match, location, history, touristRouteId }) => {  
const [data, setData] = useState<any>(null); 
 useEffect(() => {    fetchData();  }, []); 
 const fetchData = async () => {   
  try {      
  const response = await fetch(`API_URL/${touristRouteId}`);     
   const data = await response.json();      
   setData(data);   
   } catch (error) {     
    console.error(error);   
     }  
     }; 
      if (!data) {    
      return <div>Loading...</div>; // 返回加载中的占位符 
       } 
        return (    // 返回 JSX 元素   
         <div>      <h1>{data.title}</h1>      // ...    
         </div>  
         );
         };
         export default MyComponent;

Argument of type ‘{ payload: undefined; type: “userSlice/logOut”; }’ is not assignable to parameter of type ‘LanguageActionTypes’. Type ‘{ payload: undefined; type: “userSlice/logOut”; }’ is not assignable to type ‘InterLanguageNew’. Types of prope

网络请求

axios

安装axiosnpm i axios 自带TS

对悬空数据做预处理!!!!!

先执行构造函数,productList为空,紧接着会渲染UI,这时候为空,而componnetDidMount会在组件完全挂载完后执行,所以报错。
处理方法一:在没有数据的时候显示加载中…

避免在useEffect中一直请求网络数据

在这里插入图片描述

App.tsx
Header.tsx(显示购物车中有几种)
DetailPage.tsx(添加到购物车的动作)


http://www.niftyadmin.cn/n/5418532.html

相关文章

嵌入式Qt 制作一个登录对话框

一.登录对话框需求分析 二.代码实现 main.c&#xff1a; #include <QtGui/QApplication> #include "widget.h"int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); }Widget.h&#xff1a; #ifndef _WIDGET_H_…

关于天线综合2

线源波束赋形的综合方法 我们需要实现方向图特定形状的赋形。比如需求视角内宽波束(方向图长得类似“方波”)&#xff0c; 最暴力的方法当然是用算法进行全空间搜索&#xff0c;例如将每个单元的幅度和相位作为待优化变量&#xff0c;设计好适应度函数&#xff0c;用遗传算法不…

[nlp入门论文精读] | Transformer

写在前面 最近工作从CV转向了NLP&#xff0c;于是空余时间便跟着哔哩哔哩李沐老师的视频学习。其实研一NLP课程讲论文的时候&#xff0c;我们小组就选择了经典的Attention和Bert&#xff0c;但还有很多细节并不完全理解&#xff0c;实际使用时也很困惑。 因此这个系列就来记…

解决eclipse上启动不了tomcat问题

一、问题&#xff1a;在eclipse上启动不了tomcat 网上搜的方法基本都不行&#xff0c;改Maven配置和重建项目等等都解决不了。问题如下 严重: 子容器启动失败 java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component …

Vue3 子/父组件相互调用

1&#xff1a;子组件调用父组件 父组件&#xff1a; <template><div><button style"margin: 50px">父按钮</button> <!--已clk为名称的事件传递给子组件&#xff0c;传递的是父组件的a函数/事件 --><Child clk"a" />…

RAG(检索增强生成): 上下文整合

在RAG&#xff08;检索增强生成&#xff09;系统中&#xff0c;上下文整合是将检索到的信息与用户查询相结合的过程&#xff0c;以便为生成阶段提供丰富的背景知识。这一步骤对于生成准确、相关且信息丰富的文本至关重要。以下是上下文整合的一些关键方案和技术实现&#xff1a…

C++ 疑难点

C疑难点 this指针 调用成员函数时&#xff0c;成员函数通过一个名为 this 的隐式参数来访问调用它的那个对象&#xff0c;用请求该函数的对象地址初始化 this &#xff0c;this 的指向总是自己这个对象&#xff0c;所以 this 是一个常量指针 Box* get_address() //得到thi…

【Demo】游戏小地图

简介 该Demo基于2D关卡随机生成项目进行实现&#xff0c;旨在初步探索游戏小地图的制作。 演示 MiniMapDemo 资源下载 百度网盘&#xff08;提取码&#xff1a;1314&#xff09; 如果这篇文章对你有帮助&#xff0c;请给作者点个赞吧&#xff01;