初窥.contains 在 react 中应用的冰山一角 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
devwolf
V2EX    React

初窥.contains 在 react 中应用的冰山一角

  •  
  •   devwolf
    yctjb1 2022-07-15 13:53:07 +08:00 2121 次点击
    这是一个创建于 1182 天前的主题,其中的信息可能已经有所发展或是发生改变。

    契机:最近有在一则简书 https://www.jianshu.com/p/f1958db7234c 中认知到 useRef 的返回对象里有个.current.contains 这样的方法(该例子讲的是如何点击指定 ref 以外的内容来触发某个方法)。
    正好今天有空,查了一下,发现描述比较少,可能搜索用的关键词不得要领。 大致查到了如下几个线索: https://developer.mozilla.org/zh-CN/docs/Web/API/Node/contains
    https://developer.mozilla.org/zh-CN/docs/Web/API/DOMTokenList/contains
    首先是node.contains( otherNode ),原生的 js 节点对象上有这个方法,表示传入的节点是否为该节点的后代节点。Element.classList这样得到的 DOMTokenList 对象也有.contains 方法,不过此时传入的值是类名

    https://bobbyhadz.com/blog/react-check-if-element-has-class 这个网站的例子向我展示了在 react 中后者的两种应用ref.current.classList.contains('my-class') 以及event.currentTarget.classList.contains('my-class')

    这么一来,我才醒悟,我并不知道 react 中的 ref 和 event 具体多了哪些其实很有用的新方法(除了 react 官网介绍的那些),想找个更全一点的,类似 mdn 上那样很全的对象描述。
    有找到一篇 https://blog.logrocket.com/complete-guide-react-refs/ 这样的 ref 指南,
    想问问各位 v 友还有没有其他的相关好文推荐

    2 条回复    2022-07-15 14:18:39 +08:00
    anjianshi
        1
    anjianshi  
       2022-07-15 14:16:43 +08:00   1
    这是浏览器 DOM 自带的方法。和 React 没有关系。
    你这里 ref.current 的值就是一个浏览器原生的 DOM 节点。

    想知道所有可以用的属性和方法,就看 MDN 就够了。
    https://developer.mozilla.org/zh-CN/docs/Web/API/Element
    https://developer.mozilla.org/zh-CN/docs/Web/API/Node
    把里面的“属性”方法“挨个了解一遍
    devwolf
        2
    devwolf  
    OP
       2022-07-15 14:18:39 +08:00
    @anjianshi 噢噢,好的,感谢更正,那我学习的大方向确定了
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1110 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 23:17 PVG 07:17 LAX 16:17 JFK 19:17
    Do have faith in what you're doing.
    ubao 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