React
JSX基本使用
变量, 表达式
{} => 插值
被包裹就是变量或者表达式
Class style
class 需要写 className
style
- style={{}} =>直接写
- 变量styleData = {fontSize: ‘30px’} style={styleData}
子元素与组件
<首字母大写>
判断
同js一样
三元表达式
列表渲染
map
key
事件
bind this
关于event参数
//普通方法默认undefined
this.xxMethod = this.xxMethod.bind(this)
(constructor中绑定性能更好)
//静态方法,this 指向当前实例(箭头函数定义方法)
//阻止默认行为(冒泡)
xxHandler = (event) => {
event.preventDefault() //阻止默认行为
event.stopPropagation() //阻止冒泡
}
event由react提供,非原生
表单
value= this.state.xx
state控制的为受控组件
组件使用
props 传递数据
props 传递函数
props 类型检查
setState
- 不要直接修改state,使用不可变值 不可提前修改值,在修改时赋值
setState 是同步还是异步
可能是异步 => 正常是异步
可能是同步 => setTimeout 同步 / 自定义DOM事件 同步
setState 合并
多次合并 只执行一次
组件生命周期
挂在
constructor
render
React 更新DOM ref
componentDidMount / componentWillMount
销毁
shoudUpdate
React高级特性
函数组件
function xx(props){
return jsx
}
- 纯函数,输入props,输入JSX
- 没有实例,没有生命周期,没有state
- 不能扩展其他方法
非受控组件 ?
ref
defaultValue defaultChecked
手动操作DOM元素
this.xxRef = React.createRef()
<input defaultValue = { this.state.name } ref = { this.xxRef } >
this.xxRef.current => 获取
文件上传 input type = file
富文本编辑器
Portals ?
传送层级
让组件传送到父组件外
context ?
公共信息(语言,主题)如何传递给每个组件
用props太繁琐
用redux小题大做
生成
const xxContext = React.createContext('test')
使用
<xxContext value={this.state.xxx}>
...
</xxContext>
消费
xx组件.contextXX = xxContext
this.context 使用
异步组件
性能优化, 路由较大
import
React.lazy
React.Suspense
const ContextDemo = React.lazy(()=> import(’./ContextDemo’))
<React.Suspense fallback={
性能优化
如何插入一段漂亮的代码片
去博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片
.
// An highlighted block
var foo = 'bar';
生成一个适合你的列表
- 项目
- 项目
- 项目
- 项目
- 项目1
- 项目2
- 项目3
- 计划任务
- 完成任务
创建一个表格
一个简单的表格是这么创建的:
项目 | Value |
---|---|
电脑 | $1600 |
手机 | $12 |
导管 | $1 |
设定内容居中、居左、居右
使用:---------:
居中
使用:----------
居左
使用----------:
居右
第一列 | 第二列 | 第三列 |
---|---|---|
第一列文本居中 | 第二列文本居右 | 第三列文本居左 |
SmartyPants
SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:
TYPE | ASCII | HTML |
---|---|---|
Single backticks | 'Isn't this fun?' | ‘Isn’t this fun?’ |
Quotes | "Isn't this fun?" | “Isn’t this fun?” |
Dashes | -- is en-dash, --- is em-dash | – is en-dash, — is em-dash |
创建一个自定义列表
-
Markdown
- Text-to- HTML conversion tool Authors
- John
- Luke
如何创建一个注脚
一个具有注脚的文本。1
注释也是必不可少的
Markdown将文本转换为 HTML。
KaTeX数学公式
您可以使用渲染LaTeX数学表达式 KaTeX:
Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n−1)!∀n∈N 是通过欧拉积分
Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=∫0∞tz−1e−tdt.
你可以找到更多关于的信息 LaTeX 数学表达式[here][1].
新的甘特图功能,丰富你的文章
- 关于 甘特图 语法,参考 [这儿][2],
UML 图表
可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:
这将产生一个流程图。:
- 关于 Mermaid 语法,参考 [这儿][3],
FLowchart流程图
我们依旧会支持flowchart的流程图:
- 关于 Flowchart流程图 语法,参考 [这儿][4].
注脚的解释 ↩︎