目录antd
1、组件结构this
一、antd代码结构spa
二、rc-ant代码结构component
三、组件结构对象
2、antd组件调用关系及功能详解blog
一、Model.tsx生命周期
二、confirm队列
3、rc-dialog详解事件
一、e.target 与 e.currentTarget图片
二、onMouseDown、onMouseUp 和 onClick
三、理解dialog中的鼠标事件
四、思惟导图
1、组件结构
一、ant代码结构

二、rc-ant代码结构

三、组件结构
ant中modal的index.tsx中引入了Modal和confirm
Modal包含的不一样状态method(info、Sucesses等)都是经过调用confirm方法传递不一样参数实现
Modal中引用rc-dialog,作弹窗的渲染
2、antd组件调用关系
一、Model.tsx
modal中的方法包括
-
handleCancel:在点击取消按钮时触发,触发时调用this.props.onCancel()
- handleOk:在点击OK按钮时触发,触发时调用this.props.onOk()
-
componentDidMount:生命周期,挂在完成时触发
-
renderFooter:确认、取消按钮所在的弹框底部内容处理
-
render:渲染方法,包括本地化等
- Modal.method():Modal容许使用method方法建立信息提示框,包含五种方法均引自confirm

二、confirm
confirm中的方法包括

上图中代码图片清晰大图以下:

3、rc-dialog详解
一、e.target 与 e.currentTarget
- currentTarget: event对象属性,返回当前处理该事件的元素、文档或窗口。
- target: event对象属性,返回触发该事件的元素、文档或窗口。
二、onMouseDown、onMouseUp 和 onClick
若是用户在一个元素上点击,那么最少三个事件会被触发,事件发生顺序:
- mousedown,当用户在这个元素上按下鼠标键的时候
- mouseup,当用户在这个元素上松开鼠标键的时候
- click,当一个mousedown和一个mouseup都在这个元素上被检测到的时候发生
- 由第3点引伸:鼠标在mousedown和mouseup之间移动拖拽的,根据时间冒泡,mouseup、mousedown所在的公同父元素会触发click事件
三、理解dialog中的鼠标事件
3.1 mousedown在dialog外click的执行顺序
- 触发onMaskMouseUp:if条件不知足,什么操做都不执行
- 触发onMaskClick:!this.dialogMouseDown必定成立,e.target 与 e.currentTarget值也相同
- 结果:关闭弹窗
- 注:mousedown在dialog外,mouseup在dialog内时,click中 e.target === e.currentTarget 依然成立,都是Mask。结果不变,关闭窗口
3.2 mousedown在dialog内click的执行顺序
- 触发onDialogMouseDown:this.dialogMouseDown赋值为true
- 触发onMaskMouseUp:if条件成立,timeout事件加入任务队列
- 触发onMaskClick:this.dialogMouseDown 为true,if条件不成立
- 结果:不关闭弹窗
- timeout事件执行:this.dialogMouseDown还原为false
- 注:mousedown在dialog内,mouseup在dialog外时,click中 e.target === e.currentTarget 依然成立,都是Mask。this.dialogMouseDown 也依然为true。结果不变,不关闭窗口
四、思惟导图
