首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何检查元素是否有效

如何检查元素是否有效
EN

Stack Overflow用户
提问于 2019-10-25 13:41:58
回答 2查看 4.2K关注 0票数 4

是否可以检查对象是否为JSX我对反应和预演感兴趣。

代码语言:javascript
复制
var x = <App/>
var y = <div>xxx</div>

我想出了这个:

代码语言:javascript
复制
function isJSX(x) {
   return typeof x.props === 'object' && x.props !== null && typeof x.type !== 'undefined';
}

有更好的办法吗?我不确定其他库,如HyperApp和Preact。这个功能可靠吗?输出来自Babel。是否有一个规范可以显示JSX转发程序的输出应该是什么?

这是我的测试笔

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-10-25 13:52:21

jsx主要是React.createElement的句法糖。您可以使用isValidElement ( React提供的助手)来检查给定的element是否有效。

代码语言:javascript
复制
const isValid = React.isValidElement(element)
票数 11
EN

Stack Overflow用户

发布于 2019-10-25 13:53:31

也许你需要React.isValidElement

一些来自反应源的测试。

ReactElement:/ReactElement-test.js#L 298-L 318

ReactJSXElement:/ReactJSXElement-test.js#L156-L166

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58559714

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档