V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
iliaoliao
V2EX  ›  程序员

在推特上搜了一下自己的项目发现居然不少人有在讨论

  •  
  •   iliaoliao ·
    liaoliao666 · 2023-03-28 10:35:09 +08:00 · 3122 次点击
    这是一个创建于 607 天前的主题,其中的信息可能已经有所发展或是发生改变。

    看了这个主题 这个小项目,上周被国外 AI 新闻网站报道,前些天又上了 github 热榜,也想分享我的开源项目 react-query-kit。虽然这个库的源码非常简单,打包后仅占用半个 kb 的大小,但在 TypeScript 类型推断方面做了很多工作。

    react-query 是一个强大的前端请求缓存库,但在我在公司的一些大型项目中使用时遇到了一些痛点。因此,我创建了这个库来解决这些问题。我相信很多人都会遇到类似的问题,因此在去年底,我将代码开源了。最近,我在 Twitter 上搜索时发现还有很多人在谈论这个库,甚至 react-query 的作者也在推荐它,瞬间那种被认同感就上头了。

    由于我没有在国内推广过,目前这个库的点赞主要来自海外用户,已经获得了 100 多个 star 。如果你正在使用 react-query ,你可以尝试使用 react-query-kit 来提高开发体验。

    项目地址 https://github.com/liaoliao666/react-query-kit

    第 1 条附言  ·  2023-03-28 14:12:57 +08:00

    twiter 截图
    截图一 截图二 截图三

    该项目一个用于 ReactQuery 的工具包,它能使 ReactQuery 更易复用和类型安全。旨在创建一个 ReactQuery hook 像创建一个函数容易。下面是一个基础例子

    type Response = { title: string; content: string }
    type Variables = { id: number }
    
    const usePost = createQuery<Response, Variables, Error>({
      primaryKey: '/posts',
      queryFn: ({ queryKey: [primaryKey, variables] }) => {
        // primaryKey 相等于 '/posts'
        return fetch(`${primaryKey}/${variables.id}`).then(res => res.json())
      },
      // 如果你只想在有id时且没有数据时请求,可以这么设置
      enabled: (data, variables) => !data && variables.id,
      suspense: true,
       // 你也可以通过 useDefaultOptions 传入默认选项
      useDefaultOptions: () => {
        const { id } = useSomething()
        return {
          variables: { id }
        }
      }
    })
    
    4 条回复    2023-03-28 14:18:01 +08:00
    alne
        1
    alne  
       2023-03-28 12:31:44 +08:00   ❤️ 8
    也不用这样硬推吧
    ae86
        2
    ae86  
       2023-03-28 13:05:45 +08:00
    你一不贴 twitter 链接, 二不讲下解决了什么痛点,直接贴个仓库链接,反感+++++++++
    Jaosn
        3
    Jaosn  
       2023-03-28 13:42:51 +08:00
    现在这种文分有点《如何评价 xxx 》内味了
    iliaoliao
        4
    iliaoliao  
    OP
       2023-03-28 14:18:01 +08:00   ❤️ 1
    @alne @ae86
    因为是 ReactQuery 的一个衍生库,我在文章中说解决什么痛点在大部分没有用的人怎么也感知不到,感兴趣的人在项目 readme 中就可以看到解决什么痛点了。

    @Jaosn 我的文笔不大行,有点太官方了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1144 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 23:38 · PVG 07:38 · LAX 15:38 · JFK 18:38
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.