mobx hook中的使用
class
import { inject, observer } from "mobx-react";
// 需要使用mobx-react提供的Provider 包裹,需要使用的值直接使用props传递
import { Provider } from "mobx-react";
<Provider {...store}>{children}</Provider>
// inject把需要使用的值放到props里
// 这里使用的observer来自mobx-react
@inject('store')
@observer
class A extends React.Component {
...
this.props.store.value
}function
import { createContext, useContext } from 'react';
const store = {
...
}
// createContext接受一个参数,该参数是Ctx.Provider上的value的默认值,没有默认值就给null
const Ctx = createContext(store);
const {Provider ,Consumer} = Ctx;
// useContext接受createContext创建的context对象
// useContext返回Ctx.Provider上的value值
const useStore = () => useContext(Ctx);
// 使用的时候需要被Ctx.Provider包裹,把对象赋给value
<Ctx.Provider value={store}>
</Ctx.Provider>
<Consumer>{value => ...}</Consumer>
// function component 需要用mobx-react-lite里observer处理
// class使用的mobx-react里的observer,这里是不同的
import { observer } from "mobx-react-lite";
const B: React.FC =e () => {
// 可以直接解构拿值
const store = useStore();
}
export observer(B);
项目中的运用class
// apps\link\src\solutions\biz-form\page\menu-buttons\pur-order-generate\PurOrderGenerate.tsx
import * as React from "react"; import { BizFormPresenter } from '../presenter/BizFormPresenter'; const context = React.createContext<BizFormPresenter>(null); export const PresenterProvider = context.Provider;
// class 使用方法
export const PresenterConsumer = context.Consumer;
// function 使用方法
export const useBizFormPresenter = () => React.useContext(context); @contextProvider(PresenterConsumer, 'presenter')
@observer
export class PurOrderGenerateBtn extends React.Component<{
presenter?: BizFormPresenter;
entityName: string;
}> { }
export function contextProvider<P1, P2, PassName extends string = 'passContextValue'>(ContextConsumer: React.ComponentType<React.ConsumerProps<P2>>, passPropName: PassName = "passContextValue") {
return (ComponentClass: React.ComponentType<P1 & { [key in PassName]?: P2 }>) => {
class WrappedComponent extends React.PureComponent<P1 & { [key in PassName]?: P2 } & { passContextValue?: P2 }> {
render() {
return (
<ContextConsumer>
{
(value: P2) => { const passProps: { [key in PassName]: P2 } = {
[passPropName]: this.props[passPropName] || value
} as any; return (
<ComponentClass {...this.props} {...passProps} />
);
}
}
</ContextConsumer>
);
}
}; hoistNonReactStatics(WrappedComponent, ComponentClass);
return WrappedComponent as any;
}
}
项目中的运用hook
// apps\link\src\main\screens\purchase\pur-comparison\form\customizeRightButtons.tsx
const context = React.createContext<BizFormPresenter>(null); const CustomizeRightButtons: React.FC<CustomizeRightButtonsPropsModel> = (props) => {
const presenter = useBizFormPresenter(); return (
<>
{presenter.api.getFrom().value}
</>
);
}; export default observer(CustomizeRightButtons);
不需要响应式
//直接调用
store.value
useLocalObservable
import { Observer, useLocalObservable } from "mobx-react-lite"; export default function MobxCount() {
// 可以用来代替 useState useCallBack
const state = useLocalObservable(() => ({
count: 10,
increment() {
state.count++;
},
decrement() {
state.count--;
},
})); return (
<div>
<Observer>{() => <div>{state.count}</div>}</Observer>
<button
onClick={() => {
state.decrement();
}}
>
decrement
</button>
<button
onClick={() => {
state.increment();
}}
>
increment
</button>
</div>
);
}
mobx hook中的使用的更多相关文章
- MobX 在 hook 中的使用
关于 mobX 在 react 16.8.0 以上的用法 以下例子均取自官网文档 一般用法: import { observer, useLocalStore } from 'mobx-react'; ...
- hook中ref使用
hook使用ref 父组件: 引入 useRef 声明ref的名字 const dateRef = useRef() 复值给组件 ref={d ...
- TS基础应用 & Hook中的TS
说在前面 本文难度偏中下,涉及到的点大多为如何在项目中合理应用ts,小部分会涉及一些原理,受众面较广,有无TS基础均可放心食用. **>>>> 阅完本文,您可能会收获到< ...
- React MobX 开始
MobX 用于状态管理,简单高效.本文将于 React 上介绍如何开始,包括了: 了解 MobX 概念 从零准备 React 应用 MobX React.FC 写法 MobX React.Compon ...
- CI框架源码阅读笔记6 扩展钩子 Hook.php
CI框架允许你在不修改系统核心代码的基础上添加或者更改系统的核心功能(如重写缓存.输出等).例如,在系统开启hook的条件下(config.php中$config['enable_hooks'] = ...
- Linux LSM(Linux Security Modules) Hook Technology
目录 . 引言 . Linux Security Module Framework Introduction . LSM Sourcecode Analysis . LSMs Hook Engine: ...
- Git Server & Git Hook
http://ju.outofmemory.cn/entry/16893 我喜欢 github,我现在的个人代码全部是托管在上面了,但是一些公司或者某些项目不适合放入github中,你希望能有一个完全 ...
- HOOK API 在多线程时应该注意的问题点
在使用INLINE HOOK API实现对系统API的拦截时,正常情况下并没有太大问题,但一旦涉及到多线程,不管是修改IAT还是JMP,2种方法均会出现不可预料的问题,特别是在HOOK一些复杂的大型系 ...
- API HOOK
API HOOK技术是一种用于改变API执行结果的技术,Microsoft 自身也在Windows操作系统里面使用了这个技术,如Windows兼容模式等. API HOOK 技术并不是计算机病毒专有技 ...
- API HOOK技术
API HOOK技术是一种用于改变API执行结果的技术,Microsoft 自身也在Windows操作系统里面使用了这个技术,如Windows兼容模式等. API HOOK 技术并不是计算机病毒专有技 ...
随机推荐
- 【Java】自定义mybatis
处理 sql in 多条件搜索时 单引号双引号问题 StringBuilder pidNoZeroIds = new StringBuilder(); Integer numTmp = 0; for ...
- 微服务减少jar包体积
<build> <finalName>${project.artifactId}</finalName> <plugins> <!--打包jar- ...
- C - Perform the Combo
C - Perform the Combo 思路:当读到这个题的时候,第一反应就是枚举,但是,无线超时,没办法,那就变,利用前缀和,减少时间. 代码: #include<iostream> ...
- (一)用go实现单链表
本篇,我们用go简单的实现单链表这种数据结构. 1.节点定义 type Node struct{ data int next *Node } 2.节点的添加 // 尾插法插入节点 func (p *N ...
- (原创)odoo15(master)下,列表导出权限控制
列表导出增加一个内置用户组"base.group_allow_export"以增强权限控制.
- dart+flutter中使用PaginatedDataTable分页时最后一页多出空白行问题
使用PaginatedDataTable时解决最后一页不够当前行的话会有很空白行的问题 解决的场景: 比如下图,28行数据,每页5行最后一页会多出两行空白. 解决方法: 可以使用PaginatedDa ...
- 51电子-STC89C51开发板:回忆
全部内容,请点击: 51电子-STC89C51开发板:<目录> --------------------------- 正文开始 --------------------------- ...
- Java——四种线程创建方式
java中创建线程有四种方式,分别是:继承Thread类,重写run方法,然后创建线程对象并调用start方法.实现Runnable接口,实现run方法,然后创建线程对象并传入Runnable实例,再 ...
- php curl方法封装
/** * @desc 获取设备的监控项实时值 * * @return url请求地址 * @return method 请求方法(POST,GET,PUT)等 * @return postfiel ...
- 批量检测URL中的关键词,并且将不含有关键词的URL输出到txt文件当中
编写代码时遇到的问题 写入txt(一开始忘记了tuple类型需要转换为str) 处理逻辑(一开始并没有将 body与url绑定到一起,所以或返回所有的url) 关闭太早(这点是有点疑惑的,难道不用关闭 ...