| |
|
开发:
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新生命周期之getSnapshotBeforeUpdate -> 正文阅读 |
|
[JavaScript知识库]React新生命周期之getSnapshotBeforeUpdate |
<!DOCTYPE html> <html> <head> ? ? <meat charset="UTF-8"> ? ? ? ? <title>新react生命周期</title> </head> <body> ? ? <!-- 准备好一个容器 --> ? ? <div id="test"></div> ? ? <!-- 核心库 --> ? ? <script type="text/javascript" src="../js/react.development.js"></script> ? ? <!-- react-dom,操作dom --> ? ? <script type="text/javascript" src="../js/react-dom.development.js"></script> ? ? <!-- 引入babel,jsx转为js --> ? ? <script type="text/javascript" src="../js/babel.min.js"></script> ? ? <!-- 此处一定要写babel --> ? ? <script type="text/babel"> ? ? ? ? //1.创建组件 ? ? ? ? class Count extends React.Component{ ? ? ? ? ? //构造器 ? ? ? ? ? constructor(props){ ? ? ? ? ? ? ? console.log('Count---constructor'); ? ? ? ? ? ? ? super(props) ? ? ? ? ? ? ? ?//初始化状态 ? ? ? ? ? ? ? this.state = { count: 0 } ? ? ? ? ? } ? ? ? ? ? //加1按钮的回调 ? ? ? ? ? add = ()=>{ ? ? ? ? ? ? //获取原状态 ? ? ? ? ? ? const {count} =this.state ? ? ? ? ? ? //更新状态 ? ? ? ? ? ? this.setState({count: count+1}) ? ? ? ? ? } ? ? ? ? ? death = ()=>{ ? ? ? ? ? ? ? ReactDOM.unmountComponentAtNode(document.getElementById('test')) ? ? ? ? ? } ? ? ? ? ? //强制更新按钮的问题 ? ? ? ? ? force =()=>{ ? ? ? ? ? ? ? this.forceUpdate() ? ? ? ? ? } ? ? ? ? ? //若state的值在任何时候取决于props,那么可以使用getDerivedStateFromProps ? ? ? ? ? static getDerivedStateFromProps(props,state){ ? ? ? ? ? ? ? console.log('getDerivedStateFromProps',props,state) ? ? ? ? ? ? ? return null ? ? ? ? ? } ? ? ? ? ? ? //在更新之前获取快照 ? ? ? ? ? getSnapshotBeforeUpdate(){ ? ? ? ? ? ? ? console.log('getSnapshotBeforeUpdate') ? ? ? ? ? ? ? return 'atguigu' ? ? ? ? ? } ? ? ? ? ? ? ? //组件挂载完毕的钩子 ? ? ? ? ? componentDidMount(){ ? ? ? ? ? ? ? console.log('Count---componentDidMount') ? ? ? ? ? } ? ? ? ? ? //组件将要卸载的钩子 ? ? ? ? ? componentWillUnmount(){ ? ? ? ? ? ? ? console.log('Count---componentWillUnmount') ? ? ? ? ? } ? ? ? ? ? //控制组件更新的‘阀门’ ? ? ? ? ? shouldComponentUpdate(){ ? ? ? ? ? ? ? console.log('Count---shouldComponentUpdate') ? ? ? ? ? ? ? return false; ? ? ? ? ? } ? ? ? ? ? ? ? //组件更新完毕的钩子 ? ? ? ? ? ? componentDidUpdate(preProps,preState,snapshotValue) { ? ? ? ? ? ? ? ? console.log('Count---componentDidUpdate',preProps,preState, snapshotValue) ? ? ? ? ? ? } ? ? ? ? ? ?render(){ ? ? ? ? ? ? ? ? ? console.log('Count---render') ? ? ? ? ? ? ? ? const {count}=this.state ? ? ? ? ? ? ? ?return( ? ? ? ? ? ? ? ? ? <div> ? ? ? ? ? ? ? ? ? ? <h2>当前求和为:{count}</h2> ? ? ? ? ? ? ? ? ? ? <button onClick={this.add}>点我+1</button> ? ? ? ? ? ? ? ? ? ? ? <button onClick={this.death}>卸载组件</button> ? ? ? ? ? ? ? ? ? ? ?<button onClick={this.force}>不更改任何状态中的数据,强制更新一下</button> ? ? ? ? ? ? ? ? ? </div> ? ? ? ? ? ? ? ? ? ? ? ?) ? ? ? ? ? ? ? ? ? ? ?} ? ? ? ? } ? ? ? ? ? ? ? ? ? //2.渲染组件到页面 ? ? ? ? ReactDOM.render(<Count count={199}/>, document.getElementById("test")); ? ? ? </script> </body> </html> |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/11 2:56:12- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |