IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> react面试 -> 正文阅读

[JavaScript知识库]react面试

函数定义组件与类定义组件的区别

  1. 类定义组件有生命周期,函数定义的没有;
  2. 类定义有state,函数定义没有;
  3. 对于父组件传递的数据,类定义组件通过this.props接收,函数定义通过props接收。
  4. 对于类定义,每调用一次,就会实例化一个对象,而对于函数组件,只是单纯的计算,所以函数的性能高于类定义。

受控组件与非受控组件的区别

受控组件:通过事件触发由e.target.value获取表单元素的值的组件。可以实时验证,可以禁用提交按钮

非受控组件:通过ref对象获取表单元素的值的组件

容器型组件和展示型组件有什么区别

容器型组件

  1. 类定义组件
  2. 数据来自与redux
  3. 对redux有感知

展示型组件

  1. 函数定义组件
  2. 数据来自父组件
  3. 对redux没有感知

ref

可以获取DOM元素,也可以获取组件实例

  1. 创建一个ref对象this.名= React.createRef();
  2. 将对象绑定到元素上 <div ref={this.名}></div>
  3. 操作refthis.名.current

react 特点

  1. 使用虚拟 DOM 而不是真正的 DOM
  2. 可以用服务器端渲染
  3. 遵循单向数据流或数据绑定

react生命周期

初始期:渲染DOM节点

更新期:调和过程,进行diff算法,计算出最优的更新方式,局部更新

1.初始期

(1)constructor(){}:初始化数据

(2)render(){return()}:渲染DOM

(3)componentDidMount(){}:渲染完成

? 作用:计时器、发送请求,window|document添加事件、获取DOM

2.更新期(state、props)

shouldComponentUpdate(nextProps,nextState){return} : 判断是否更新。调和过程,进行diff算法,计算出最优的更新方式,局部更新

nextPropsthis.props比较return false,可以实现按需更新子组件

(1)return true/false没有return内容,报错
(2)如果return true.

? 更新流程 1shouldComponentUpdate(){return true}–>2render(){return}–>3componentDidUpdate(){}

(3) 如果return false.则不更新

3.销毁期

componentWillUnmount(){} 销毁之前

? 一般用于,清除计时器 取消window|document事件

组件传值

父传子

给子组件设置自定义属性,子组件为函数注册的使用props接收,函数注册使用this.props接收(在render(){}中)

子传父

父组件通过自定义属性传递方法,子组件通过props调用进行传参

redux

三大原则

  1. 单一数据源
  2. state是只读的
  3. 只能通过纯函数修改state

创建redux仓库

安装npm i redux --save

  1. 初始状态initState={}
  2. 修改数据的types
  3. actions={}方便派发任务
  4. function reducer(){}修改数据
  5. 创建仓库let store = createStore(reducer)
  6. 导出
//引入方法
import { createStore } from "redux"

//初始状态
const initState = {
    name: "妲己",
    age: 20
}

// 修改的types
const types = {
    // 修改name
    CHANGE_NAME: "CHANGE_NAME",
    // 修改age
    CHANGE_AGE: "changeAge"
}

//action creator [vuex actions] 方便组件派发任务
export let actions = {
    changeName: (name) => ({ type: types.CHANGE_NAME, name: name }),
    changeAge: (age) => ({ type: types.CHANGE_AGE, age })
}

function reducer(state = initState, action) {
    switch (action.type) {
        case types.CHANGE_NAME:
            return {
                ...state,
                name: action.name
            };
        case types.CHANGE_AGE:
            return {
                ...state,
                age: action.age
            };
        default:
            return state;
    }
}

// 创建仓库
let store = createStore(reducer)

//导出仓库
export default store;

react-redux使用

  1. 安装npm i react-redux --save
  2. 关联。在index.js设置store={store}

在reducer中允许异步

npm i redux-thunk --save

使用使用中间件

import {applyMiddleware } from "redux"
let store = createStore(reducer, applyMiddleware(myLogger, checkError))

使用redux

在类定义组件中使用

引入connect()函数,函数中有两个回调函数分别为mapStateToProps(作用:将仓库里面的数据导入到this.props上)和mapDispatchToProps(作用:将仓库的方法导入到this.props上),最后导出组件export default connect(mapStateToProps, mapDispatchToProps)(组件名);

一般我们会使用bindActionCreators将所有的方法全部导入到this.props.methods

import { actions } from "../store";
import { bindActionCreators } from "redux";
let mapDispatchToProps = (dispatch) => ({
  methods: bindActionCreators(actions, dispatch),
});

路由

设置路由模式

import {HashRouter,BrowserRouter} from "react-router-dom"

ReactDOM.render(
  <HashRouter>
    <App />
  </HashRouter>
  ,
  document.getElementById('root')
);

路由出口、路由规则、重定向、懒加载

import React,{Suspense} from 'react';
import {Switch,Route,Redirect} from "react-router-dom"
let Login = React.lazy(() => import("./pages/Login/Login"))
let NotFound = React.lazy(() => import("./pages/404/404"))
const App = () => {
  return (
    <React.Suspense fallback={<div>正在加载中...</div>}>
      {/* 路由出口 */}
      <Switch>
        {/* 路由规则 */}
        <Route path="/login" component={Login}></Route>
        {/* 重定向 */}
        <Redirect to="/login"></Redirect>

        {/* 404 404千万不要设置精确匹配exact,这句写在最后*/}
        {/* <Route path="/" component={NotFound}></Route> */}
      </Switch>
     </React.Suspense> 
  );
}

export default App;

路由导航

<Link to="/search">搜索</Link>
<NavLink to="/search">搜索</NavLink>

选中时动态类名activeClassName=""只能用于NavLink,可以用来设置高亮效果

编程式导航

  1. this.props.history.push("/search"); //添加新的历史记录
  2. this.props.history.replace("/search"); // 用新的历史记录替换当前历史记录
  3. this.props.history.goBack(); //返回
  4. this.props.history.go(-1);// 返回

路由传参

?传参

 <Link to={`/cateList?id=1&name=222`}>{item.name}</Link>

取参this.props.location.search取回来的是带问号的字符串,需要自己处理成对象

:传参

 <Link to={`/detail/1`}>{item.name}</Link>
<Route path="/detail/:id" exact component={Detail}></Route>

取值this.props.match.params.名

懒加载

1.通过React.lazy()引入组件

let Login=React.lazy(()=>import("./pages/Login/Login"))let Index=React.lazy(()=>import("./pages/Index/Index"))

2.需要将规则包裹在<React.Suspense>组件中,fallback必填

<React.Suspense fallback={<div>正在加载。。。</div>}>	<Switch>		<Route exact path="/" component={Login}></Route>        <Route path="/index" component={Index}></Route>	</Switch></React.Suspense>

浏览器渲染页面的过程

  1. 浏览器将获取的 HTML 文档并解析成 DOM 树
  2. 处理 css 标记,构成层叠样式表模式 CSSOM(css object model)
  3. 将 DOM 和 CSSOM 合并为渲染树将会被创建,代表一系列将被渲染的对象
  4. 渲染树的每个元素包含的内容都是计算过的,它被称之为布局 Layout。浏览器使用一种流式处理的方法,只需要一次 pass 绘制操作就可以布局所有的元素。
  5. 将渲染树的各个节点绘制到屏幕上,这一步被称为绘制 painting。

以上五个步骤不一定一次性顺序完成,

http 请求方法

  1. get。请求指定的页面信息,并返回实体主体。
  2. post。向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中,post 请求可能会导致新的资源的建立或已有资源的修改。
  3. head。类似于 get 请求,只不过返回的响应中没有具体的内容,用于获取报头。
  4. put。从客户端向服务器传送的数据取代指定的文档的内容。
  5. delete。请求服务器删除指定的页面。
  6. connect。http/1.1 协议中预留给能够将连接改为普通方式的代理服务器。
  7. options。允许客户端查看服务器的性能。
  8. trace。回显服务器收到的请求、主要用于测试或诊断。

http 常见状态码

  1. 200–请求成功
  2. 301–资源(网页等)被永久转移到其他 url
  3. 404–请求的资源(网页等)不存在
  4. 500–内部服务器错误
  5. 403–服务器收到请求,但是拒绝提供服务

事件代理

又称为事件委托,是 js 中常用绑定事件,意思就是把原本需要绑定在子元素的响应事件(click,keydown…)委托给父元素,让父元素担当事件监听的职务。e.target.nodeName.toLowerCase()=="li"

优点

  1. 可以大量节省内存占用,减少事件注册,比如在 ui 上代理所有 li 的 click 事件
  2. 可以实现当前新增子对象时无需再次对其绑定(动态绑定事件)

mvvm 和 mvc 的区别

  1. mvc 是比较直观的架构模式,用户操作->view(负责接收用户的输入操作)->controller(肯初栏儿)(业务逻辑处理)->model(数据持久化)->view(将结构反馈给 view)
  2. mvvm 是将数据模型数据双向绑定的思想作为核心,因此在 view 和 model 之间没有联系,通过 viewModel 进行交互,而且 Model 和 ViewModel 之间的交互式双向的,因此使徒的数据的变化会同时修改数据源,而数据源数据的变化也会立即反应到 view 上

react 和 vue 的区别

  1. 本质上的区别:模块和组件化的区别
    1. vue 本质是 mvvm 框架,由 mvc 发展而来
    2. react 是前端组件化框架,由后端组件化发展而来
  2. vue 使用模板
  3. react 使用 jsx
  4. react 本身就是组件化
  5. vue 是 mvvm 上扩展的
  6. 共同点:都支持组件化,都是数据驱动视图

jsx

  1. jsx 是 javascript XML,它是对 JavaScript 语法扩展。react 使用 jsx 来替代常规的 JavaScript。
  2. 优点:
    1. 执行速度快,因为它在编译为 JavaScript 代码后进行优化
    2. 可以使用熟悉的语法仿照 html 来定义虚拟 DOM。从而编写模块更加简单快捷
  3. jsx 当中的标签类型
    1. 有两种:DOM 类型标签(div,span 等),react 组件类型的标签
    2. DOM 类型标签需要标签首字母小写,react 类型标签需要标签首字母大写

hooks

useState()设置状态

const [name, setName] = useState("妲己");

useEffect()模拟生命周期

  1. useEffect(callback)相当于componentDidMount +componentDidUpdate(渲染完成+数据更新)
  2. useEffect(callback,[])相当于componentDidMount(渲染完成)
  3. useEffect(callback,[数据])相当于componentDidUpdate(数据更新)

useReducer()代替多个useState()

const [state, dispatch] = useReducer(reducer, initState);

useContext()父组件给子组件传值

父组件给子组件传值,子组件没用,子组件传递给了自己的子组件,这样传递,容易出错,可以使用useContext() 让父组件直接将数据传递给子组件的子组件。

组件优化

去除根节点

  1. Fragment代替div
  2. <></>代替div

子组件多次渲染问题

  • 类定义组件
    • 使用shouldCompnentUpdate(nextProps,nextState){}生命周期,判断this.props.name===nextProps.name是否相等。相等就返回false,不相等就返回true
    • 如果数据只有props,不使用Component定义类组件,改用PureComponent定义类组件
  • 函数定义组件
    • 导出时使用React.memo(组件名)
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-21 15:16:46  更:2021-08-21 15:17:59 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:23:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码