求助: 前端开发能让用户自助添加/拖动/缩放小组件的仪表面板 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
Gabrielle70

求助: 前端开发能让用户自助添加/拖动/缩放小组件的仪表面板

  •  
  •   Gabrielle70 2024 年 10 月 18 日 5284 次点击
    这是一个创建于 554 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需要前端开发一个股票/基金行情的仪表面板, 要求:

    1. 仪表面板是有 N 个小组件组成, 每个组件可以是曲线图, 也可以是动态行情数据等等
    2. 用户可以在小组件库中自行选择小组件, 增加到面板上
    3. 用户可以自助添加/拖动/缩放小组件
    4. 小组件在拖动/缩放的过程中, 布局会随时弹性适应
    5. 需适配手机和电脑
    6. 最好但不限于用 react/nextjs 框架

    问题:

    1. 有没有一站式解决的框架或 libraries
    2. 求开发思路

    谢谢

    7 条回复    2024-10-18 15:14:09 +08:00
    ZGame
        1
    ZGame  
       2024 年 10 月 18 日
    拖拽可以使用类似 react-grid-layout 这种。需要适配手机和桌面端,手机和桌面端应该没办法复用, 只能进入的时候判断是手机还是桌面端,主要是在进入界面前保存一下 componentSchema, 如果是桌面端走一分支,移动端走另一种方式的渲染。 再做完善点就是 bi 了... 有个设计器, 等于是保存两份布局 Schema 根据 type 是移动端或者桌面端分别保存
    rocmax
        2
    rocmax  
       2024 年 10 月 18 日 via Android
    Baymaxbowen
        3
    Baymaxbowen  
       2024 年 10 月 18 日 via iPhone
    @ZGame 我们类似的场景就是用了 layout ,但是自适应效果不好
        4
    mrzou007  
       2024 年 10 月 18 日
    https://golden-layout.com/ 看看这个吧。
    markyun02
        5
    markyun02  
       2024 年 10 月 18 日
    如果没有理解错的话,这个面板叫 dashboard ,我们也在做同样的功能,而且已经做好了。
    面板不同的组件是通过 map 动态生成的,整个面板可自由缩放和拖拽位置。
    ZGame
        6
    ZGame  
       2024 年 10 月 18 日
    @Baymaxbowen 这种算成熟的解决方法了吧.. 效果不好要子组件本身也要去适配。 没有银弹应该是
    codebird
        7
    codebird  
       2024 年 10 月 18 日
    superset
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     3005 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 78ms UTC 06:37 PVG 14:37 LAX 23:37 JFK 02:37
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86