问题描述
function App(){
const ref=useRef()
useEffect(()=>{
console.log(ref.current)
console.log(ref.current.offsetWidth)
},[])
return <div ref={ref}></div>
}
我得到了一些类似的代码,并试图以开玩笑的方式对其进行测试,一个基本要求是ref.current.offsetWidth
应该大于0
但是,当我安装该组件
时,ref.current
就像这样
HTMLdivelement {
'__reactContainere$36yfa3ajf2y': FiberNode {
tag: 3,key: null,elementType: null,type: null,stateNode: FiberRootNode {
tag: 0,current: [Circular],containerInfo: [Circular],pendingChildren: null,pingCache: null,finishedExpirationTime: 0,finishedWork: null,timeoutHandle: -1,context: {},
我看起来很像一个反应节点,而不是dom节点,因此开玩笑的行为与真实行为不符。
这是我要挂载的代码
mount(<App />,{attachTo:document.createElement('div')})
当我直接console.log
document.createElement('div')
时
我还是这样:
HTMLdivelement {
'__reactContainere$36yfa3ajf2y': FiberNode {
tag: 3,pendingContext: null,hydrate: false,callbackNode: null,call
document
似乎是通过jsdom作为一个笑话全局提供的,为什么它是一个react节点而不是dom节点?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)