vue 热更新的时候,使用 document 获取到的 dom 元素里面包含的内容会消失,但是 ref 获取到的不会消失,这是为什么?为什么在 vue 中获取 dom 使用 ref,而不适用 document,有什么区别吗? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
Pokemon123
V2EX    程序员

vue 热更新的时候,使用 document 获取到的 dom 元素里面包含的内容会消失,但是 ref 获取到的不会消失,这是为什么?为什么在 vue 中获取 dom 使用 ref,而不适用 document,有什么区别吗?

  •  
  •   Pokemon123 2020-11-04 17:07:38 +08:00 2305 次点击
    这是一个创建于 1857 天前的主题,其中的信息可能已经有所发展或是发生改变。
    11 条回复    2020-11-05 13:33:15 +08:00
    tanranran
        1
    tanranran  
       2020-11-04 17:11:32 +08:00
    vue 中的 dom 都是虚拟 DOM 渲染的,在没有渲染完毕之前 document 是获取不到的
    ragnaroks
        2
    ragnaroks  
       2020-11-04 17:12:17 +08:00
    ref 到的 DOM,应该是内存里面的虚拟 DOM
    document 则是实打实的 DOM,渲染的时候被替换成 <!----> 了
    Pokemon123
        3
    Pokemon123  
    OP
       2020-11-04 17:18:27 +08:00
    @ragnaroks 也就是说在没有渲染完毕之前,真实的 dom 里面的内容全是<!---->,所以我获取到的 dom 里面的内容是空的?
    xiangyuecn
        4
    xiangyuecn  
       2020-11-04 17:31:18 +08:00
    setTimeout 解决一切疑难杂症
    Pokemon123
        5
    Pokemon123  
    OP
       2020-11-04 17:36:15 +08:00
    @xiangyuecn 可以再说的详细一些吗?
    ragnaroks
        6
    ragnaroks  
       2020-11-04 17:37:42 +08:00
    你看下 vue 的 nexttick 就了解了,有提到 dom
    Pokemon123
        7
    Pokemon123  
    OP
       2020-11-04 17:45:41 +08:00
    @ragnaroks 好的,谢谢
    hongch
        8
    hongch  
       2020-11-05 10:24:08 +08:00
    可别听楼上的 setTimeout,是有多大的才会用这个蠢办法
    azcvcza
        9
    azcvcza  
       2020-11-05 10:31:37 +08:00
    ref 里存的应该是 vue 自己的一个对象,有自己的唯一 key 值与实体 dom 做对应,在 vue 更新节点后更新两者之间的联系。setTimeout 的方法是,利用 marco queue 运行比 .nextTick 和 promise 优先级慢的特点,企图在 vue 更新 dom 节点后在去用 document 获取,不是拿不到,html 上的节点怎么可能拿不到。就是不太符合 vue 的思想
    meepo3927
        10
    meepo3927  
       2020-11-05 11:21:23 +08:00
    在 vue 管理下的 dom 节点是会更新的,
    比如你用 var nodeNoRef = document.querySelecotr('.xx-node') 拿到一个节点,
    vue 触发热更新(或者是 update)之后,上面的 nodeNoRef 就可能已经不在 document 中了,只是一个即将被回收的对象。
    解决方法:
    1. 每次使用 DOM 都用 Vue 的$ref 获取 ;
    2. 在必要时使用$nextTick 。 常见场景:data 更新后,需要立即获取 DOM,可能需要在$nextTick 中来获取 DOM 。
    Pokemon123
        11
    Pokemon123  
    OP
       2020-11-05 13:33:15 +08:00
    @meepo3927 那我使用$ref 获取 dom 的时候,此时页面上还没有渲染真正的 dom 对吗?
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1014 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 18:44 PVG 02:44 LAX 10:44 JFK 13:44
    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