小编Jon*_*ynn的帖子

Redux useSelector 对对象进行过滤?

所以我使用 redux 和 useSelector 钩子从存储中获取数据。

我可以过滤reducer数组中的特定数据,以便组件仅在过滤后的数据更改时更新,例如:

const images = useSelector(state => state.Reducer.images.filter(x => x.id === someID));
Run Code Online (Sandbox Code Playgroud)

但是,当我对对象尝试相同类型的操作时,即使存储甚至没有更改,组件也总是会重新渲染。例如:

const images = useSelector(state => Object.keys(state.Reducer.images)
  .filter(x => x === someID)
  .reduce((arr, key) => {
    arr.push(state.Reducer.images[key].data);
    return arr;
  }, []));
Run Code Online (Sandbox Code Playgroud)

为什么会发生这种情况以及如何让它仅在数据更改时更新?假设将一些深度比较函数传递给 useSelector 吗?

javascript reactjs redux react-redux react-hooks

3
推荐指数
1
解决办法
6371
查看次数

golang - 从任何地方退出 http 处理程序

我正在使用 net/http 包,想知道如何从代码中的任何位置退出处理程序。假设我有这段代码:

func main() {
    http.HandleFunc("/", handler)
    http.ListenAndServe(":8080", nil)
}

func handler(w http.ResponseWriter, r *http.Request){
    err := checkSomeThing(w, r)

    if err != nil {
        return
    }

    fmt.Println("End of Handler.")
    return
}

func checkSomeThing(w http.ResponseWriter, r *http.Request) error{
    http.Error(w, "Bad Request!", http.StatusBadRequest) 
    
    return errors.New("bad request")
}
Run Code Online (Sandbox Code Playgroud)

理想情况下,我想从 checkSomeThing 函数中退出处理程序,而不必返回,然后再次返回一个级别,随着应用程序的增长,情况会变得更糟。这纯粹是为了代码的可读性。

go go-http

1
推荐指数
1
解决办法
1037
查看次数

标签 统计

go ×1

go-http ×1

javascript ×1

react-hooks ×1

react-redux ×1

reactjs ×1

redux ×1