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 ...
随机推荐
- 如何将本地未提交的更改合并到另一个Git分支?
如何在Git中执行以下操作? 我当前的分支是branch1,我做了一些本地更改. 但是,我现在意识到我实际上是要将这些更改应用于branch2. 有没有办法应用/合并这些更改,以便它们成为branch ...
- 在win10下安装ubuntu双系统总结
在打算装双系统前两天,我事先在网上买了一个16G大小的U盘,用来坐启动盘.后来发现其实有4G大小就远远足够的,16G的太浪费了,忘后来人吸取教训.呜呜呜.....下面给大家讲讲我的安装步骤: 参考文章 ...
- oracle时间处理tochar的黑幕坑
建议改成 在用别人黑不隆东,各种商业套路洗脑下的产品时,能简约弱智就被给自己留坑 做技术没踩过h2这类开源数据库的源码设计,即使砸了一堆时间看了<数据库系统基础教程>,<数据库系统实 ...
- Java面试宝典2017
JAVA面试.笔试题(2017版) 欲想成功,必须用功! 目录 一. HTML&CSS部分................ ...
- RedBlack-Tree(红黑树)原理及C++代码实现
众所周知,红黑树是用途很广的平衡二叉搜索树,用过的都说好.所以我们来看看红黑树的是怎么实现的吧. 红黑树顾名思义,通过红与黑两种颜色来给每个节点上色.其中根结点和叶子结点一定是黑色的,并且红色结点的两 ...
- [USACO09DEC]牛收费路径Cow Toll Paths(floyd、加路径上最大点权值的最短路径)
https://www.luogu.org/problem/P2966 题目描述 Like everyone else, FJ is always thinking up ways to increa ...
- 一、Shell脚本高级编程实战第一部
Shell脚本语言是实现linux系统自动化管理的重要且必要的工具,几乎每一个合格的linux系统管理员或者高级运维工程师都要熟练shell脚本语言的编写,只有这样才能提升工作效率,解决工作中的重复劳 ...
- 31)PHP,对象的遍历
对象的遍历: 对象也可以可以使用foreach语句进行便利,有两点注意: 1,只能便利属性.(所以,这个就解决了,为啥之前的数据库类,我只是看到了一些属性名字,而没有得到我的属性值) 2,只能便利“看 ...
- day35-子进程的开启
#1.异步非阻塞: import os from multiprocessing import Process def func(): print('子进程:',os.getpid()) if __n ...
- [LC] 124. Binary Tree Maximum Path Sum
Given a non-empty binary tree, find the maximum path sum. For this problem, a path is defined as any ...