React之mockjs+sass+生命周期函数
mdn W3C标准网站
运行sass
cnpm i -D node-sass-chokidar npm-run-all
rem单位设置
<script>
//rem单位设置
document.documentElement.style.fontSize = (window.innerWidth)/750 * 100 + 'px';
</script>
mock数据
1.下载mockjs
cnpm i -D mockjs
2.引入mockjs
var Mock = require('mockjs');
var fs = require('fs');
3.给出随机数据
Mock.Random.extend({
title:()=>Mock.Random.pick([1,2,3,4,5,6,7,8,9])
})
4.随机数据结果
var data = Mock.mock({
'arr|1-20':[{
'id|+1':1,
'title':'@title'
}]
})
5.写入文件data.json
fs.writeFile('./data.json',JSON.stringify(data),()=>{})
// 即出来相应的JSON数据
React 组件生命周期
1.组件的生命周期可分为三个状态:
1).Mounting: 已插入到真实DOM
2).Updating:正在被重新渲染
3).Unmounting:已移出真实DOM
2.生命周期的方法有:
1)componentWillMount 在渲染前调用,在客户端,也在服务端
2)componentDidMount:在第一次渲染后调用,只在客户端
//之后组件已经生成了对应的DOM结构,可以通过this.getDOMNode()来进行访问。 如果你想和其他JavaScript框架一起使用,可以在这个方法中调用setTimeout, setInterval或者发送AJAX请求等操作(防止异部操作阻塞UI)。
3)componentWillReceiveProps在组件接收到一个新的prop(更新后)时被调用。这个方法在初始化render时不会被调用。
4)shouldComponentUpdate 返回一个布尔值。在组件接收到新的props或者state时被调用。在初始化时或者使用forceUpdate时不被调用。
可以在你确认不需要更新组件时使用。
5)componentWillUpdate在组件接收到新的props或者state但还没有render时被调用。在初始化时不会被调用。
6)componentDidUpdate 在组件完成更新后立即调用。在初始化时不会被调用。
7)componentWillUnmount在组件从 DOM 中移除的时候立刻被调用。
8)ReactDOM.unmountComponentAtNode(document.getElementById('root'))
// 组件初始化的时候 created
constructor(props) {
super(props)
}
// 组件挂载之前 beforeMount
componentWillMount() {
}
// 组件挂载完成 mounted
componentDidMount() {
}
// 组件将要接收新的props Vue没有的
// 执行完成之后,this.props指向新的props
// 唯一一个和props相关的生命周期
componentWillReceiveProps(nextProps) {
// 旧的props this.props
// 新的props nextProps
}
// 通过返回值判断组件是否需要更新,用于React优化Vue没有的
// true更新,false不更新
shouldComponentUpdate(nextProps, nextState) {
// 旧的props this.props
// 新的props nextProps
// 旧的state this.state
// 新的state nextState
}
// 组件将要更新 beforeUpdate
componentWillUpdate(nextProps, nextState) {
}
// 组件更新完成 Updated
componentDidUpdate(prevProps, prevState) {
}
// 组件将要卸载
componentWillUnmount() {
}
卸载组件
1.挂载到Dom上时
ReactDom.unMountComponentAtNode(节点)
2.挂载在一个节点上
不渲染,等于null即可
组件
容器组件 有state数据管理
视图组件 没有state(class或函数)
// 函数(props通过函数的参数接收)
(props)=>{
}
ReactDOM.render()渲染组件时返回的是组件实例;
而渲染dom元素时,返回是具体的dom节点
this.refs 和 ReactDOM.findDOMNode区别
this.refs 获得的是虚拟DOM,而ReactDOM.findDOMNode 获得的是实际DOM。
1.ref添加到Compoennt上获取的是Compoennt实例,添加到原生HTML上获取的是DOM
2.ReactDOM.findDOMNode,当参数是DOM,返回值就是该DOM;当参数是Component获取的是该Component render方法中的DOM
refs vue中获取ref this.$refs.input
react获取ref
this.refs.input.value
<input type='text' ref='input'/>
生命周期阶段
实例化时期
react组件在实例化时会依次调用如下组件方法:
getDefaultProps
getInitialState
componentWillMount
render
componentDidMount
存在期
当react组件被实例化后,用户的一些操作会导致组件状态的更新,此时如下方法将依次被调用:
componentWillReceiveProps
shouldComponentUpdate
componentWillUpdate
render
componentDidUpdate
销毁时期
在组件销毁的时候,会调用如下组件方法:
componentWillUnmount
React之mockjs+sass+生命周期函数的更多相关文章
- react父子组件各自生命周期函数加载的先后顺序
理解记忆总结: 父组件即将挂载(最外层的父组件都还没准备进入,其内部的子组件当然更没进入了) -> 子组件即将挂载 -> 子组件挂载完成(父内部都没完成,父当然不能算完成) -> ...
- React的生命周期函数
概述 在React中,生命周期函数指的是组件在某一个时刻会自动执行的函数 constructor 在类或组件创建的时候被自动执行,我们可以说它是生命周期函数,但它并不是React所特有的,所有的Es6 ...
- React——组件的生命周期函数
每一个组件都有一些生命周期函数. 当组件实例被创建并且会插入到DOM中,下面这些函数会被调用 constructor componentWillMount render componentDidMou ...
- React 学习(四) ---- 生命周期函数
现在我们能修改状态,页面可以进行交互了,但是还有一种状态改变没有解决,那就是倒计时效果,时间一直在变化,组件状态也一直在改变,但我们什么都没有做,如果要实现这样的效果,需要怎么处理? 我们都知道,改变 ...
- React生命周期函数详解
React生命周期函数 生命周期函数是指在某一个周期自动执行的函数. React中的生命周期执行过程 以下是React中的常用的生命周期函数,按个部分中按照自动执行顺序列出,这几个过程可能存在同时进行 ...
- react生命周期函数使用箭头函数,导致mobx-react问题
最近新人加入了项目,遇到了一个很奇怪的问题.mobx observable 属性,onChange的时候就是页面不会刷新. 试来试去,就是不知道什么原因,后来其他同事查到是因为componentWil ...
- React组件详细介绍及其生命周期函数
组件的详细说明 通过Reac.createClass({...})创建组件的时候,应该有一个render()方法,也可以在其中添加生命周期函数. render方法 当调用该方法的时候,会检测this. ...
- React组件安装使用和生命周期函数
React安装在使用react时 需要安装 两个模块 react react-dom 初始化时 需要用到react-dom中的render方法 具体如下: import ReactDOM from & ...
- 2.React 生命周期函数
什么是生命周期函数:在某一时刻组件会自动调用执行的函数. import React,{ Component,Fragment } from 'react' class Note extends Com ...
随机推荐
- JS中的0b00与0x00表示什么
换成二进制表示:(0b表示二进制数,0x表示16进制数)
- RDD(二)——创建
RDD的创建 1)从内存中创建 从集合中创建RDD,Spark主要提供了两种函数:parallelize和makeRDD val raw: RDD[Int] = sc.parallelize(1 to ...
- NSIS增加打包文件夹
File /r "F:\rainwayDemo\exploer\RailwayLinesExploer\bin64\log" File /r "models" ...
- Exchang Online 保护策略
一.恶意软件筛选器 1.配置反恶意软件策略 1.1Exchange管理中心->保护->恶意软件筛选器->双击Default->编辑默认的策略 1.2单击“设置”选项,根据需要进 ...
- 监控 Linux 服务器活动的几个命令(watch top ac)
watch.top 和 ac 命令为我们监视 Linux 服务器上的活动提供了一些十分高效的途径. 为了在获取系统活动时更加轻松,Linux 系统提供了一系列相关的命令.在这篇文章中,我们就一起来看看 ...
- SSID
无线网络中SSID,是路由器发送的无线信号的名字!如果你将你的无线路由器的SSID:命名为:gouwancheng ,那么当你的无线路由器开启,并启用了无线功能,和允许了SSID广播,那么你就可以轻易 ...
- 正则表达式sed学习(二)
sedsed是一个流编辑器,非交互式的编辑器,它一次处理一行内容.处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space)接着用 sed 命令处理缓冲区的内容,处理完成 ...
- android 圆环进度view
新建RoundProgressBar class RoundProgressBar : View { private val paint = Paint() var max = 100 //最大进度 ...
- Linux 设置开机启动项的几种方法
方法一:编辑rc.loacl脚本 Ubuntu开机之后会执行/etc/rc.local文件中的脚本. 所以我们可以直接在/etc/rc.local中添加启动脚本. $ vim /etc/rc.loca ...
- T-shirt
题目描述 JSZKC is going to spend his vacation! His vacation has N days. Each day, he can choose a T-shi ...