V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
zcf0508
V2EX  ›  分享创造

为了帮助重构和优化 vue3 的代码,我构建了这个工具

  •  
  •   zcf0508 ·
    zcf0508 · 2023-08-10 13:36:51 +08:00 · 2451 次点击
    这是一个创建于 469 天前的主题,其中的信息可能已经有所发展或是发生改变。

    上链接!

    vue-hook-optimizer playground

    demo

    在左边输入 vue3 组件,然后点击 analaze 按钮,可以在右边显示组件里的变量和方法的调用。

    目前只支持 setup 语法块书写的组件,后期会考虑支持 options api 写法。


    说一下开发的动机。

    最近接手了一个很复杂的项目,单个 vue 组件里有 2000 行左右,所有的逻辑都揉在一起,而且注释也不是很完整。所以想要有一个工具,能够帮我分析一下,哪些模块是耦合比较高的,哪些部分是完全不相关的或者关联比较少的,然后可以把功能独立成 hook 来调用,这样也更容易测试。

    于是我就开发了这个工具。不过目前来看,把调用管理用图表示,能提供的帮助还是比较小的,所以在这里和大家一起讨论一下。

    1. 图的展示有哪些更好的方式,暂时计划是把节点的类型加上
    2. 我希望能够通过图和代码,自动给出一些优化建议,但是目前没有什么思路

    最后,欢迎大家点击上面的链接尝试,或者到项目主页点个 🌟 。

    10 条回复    2023-08-11 07:14:28 +08:00
    zy0829
        1
    zy0829  
       2023-08-10 13:46:48 +08:00
    个人认为你这个想法 vscode 已经自带了 比如 volar 插件
    zcf0508
        2
    zcf0508  
    OP
       2023-08-10 13:52:36 +08:00 via Android
    @zy0829 😱 volar 有这种功能吗
    bhbhxy
        3
    bhbhxy  
       2023-08-10 14:02:44 +08:00
    有没有那种可以生成常用 html+css 片段的工具,比如自动生成一个左右结构布局、列表布局、评论排行布局之类的,切图好烦
    erhsilence
        4
    erhsilence  
       2023-08-10 14:08:13 +08:00
    厉害👍,要是节点能手动添加注释就更好了
    zcf0508
        5
    zcf0508  
    OP
       2023-08-10 14:10:55 +08:00 via Android
    @erhsilence 是指在右边的节点上加注释吗,感觉有点复杂
    AuYuHui
        6
    AuYuHui  
       2023-08-10 16:18:44 +08:00
    erhsilence
        7
    erhsilence  
       2023-08-10 17:46:42 +08:00
    @zcf0508 想了想应该算是个伪需求吧,这只是我在重构一个命名不规范的项目时突然想到的一个点
    zcf0508
        8
    zcf0508  
    OP
       2023-08-10 18:33:15 +08:00 via Android
    @AuYuHui 这个只是文件调用吧,我的是希望分析文件内变量和函数的调用关系
    zcf0508
        9
    zcf0508  
    OP
       2023-08-10 19:30:33 +08:00 via Android
    @erhsilence 如果是 ts 写的,命名不规范可以直接右键重命名
    zxhy
        10
    zxhy  
       2023-08-11 07:14:28 +08:00
    @bhbhxy 已经有了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3822 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 05:16 · PVG 13:16 · LAX 21:16 · JFK 00:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.