每天一点面试题(13)------redux-trunk

react和jq一起用有什么问题
  1. 由于react 每次调用render时dom结构都会被重新绘制,因为jQuery是方便操作的DOM的库,当jQuery和REACT同时对DOM进行操作时jQuery会出现各种问题,如果实际情况需要操作DOM ,那么在shouldComponentUpdate函数中返回false
  2. 如果外部的DOM不是React组建的,那么React没法去管理。
  3. 第一,思想不一样。react是基于数据驱动的, 也就是说数据决定dom。 因此如果使用jquery的思想直接操作DOM的话,违背了这个思想。第二,两者共存可能会有意想不到的问题。 假定有这么一种场景:react的A组件,function A(props) {    return 
    <div id=“jq”>我会被jquery操作
    {props.count}}A组件props现在是{count: 1}, 然后你使用jq将id为jq的元素修改了。 然后props变为{count: 2}, react重新渲染,你会发现id为jq的元素恢复到以前的状态了。解决方式拆一个jq组件出来,并使用shouldComponentUpdate 返回false, 将组件变成不会更新的组件因此不建议在react等数据驱动的框架中做dom操作。
redux-trunk的作用

redux-thunk 是一个比较流行的 redux 异步 action 中间件,比如 action 中有 setTimeout 或者通过 fetch通用远程 API 这些场景,那么久应该使用 redux-thunk 了。redux-thunk 帮助你统一了异步和同步 action 的调用方式,把异步过程放在 action 级别解决,对 component 没有影响。下面通过例子一步步来看看。

异步方法的调用
store.dispatch({
    type: 'SHOW_NOTIFICATION', text: 'You logged in.' })
setTimeout(() => {
   
  store.dispatch({
    type: 'HIDE_NOTIFICATION' })
}, 5000)

这是一个简单的例子,他做事情很简单,5s 后关闭提醒。

在一个被 redux connect 过的 component 中,是如下这个样子:

this.props.dispatch({
    type: 'SHOW_NOTIFICATION', text: 'You logged in.' })
setTimeout(() => {
   
  this.props.dispatch({
    type: 'HIDE_NOTIFICATION' })
}, 5000)

本质上两者没有区别,只是被 connect 过的 component 中的 this.props 有了 dispatch 属性。

我们为了在不同 component 中重用创建 action 的代码,会把他放到一个 action 的 JS 文件中。

// actions.js
export function showNotification(text) {
   
  return {
    type: 'SHOW_NOTIFICATION', text }
}
export function hideNotification() {
   
  return {
    type: 'HIDE_NOTIFICATION' }
}

// component.js
import {
    showNotification
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值