首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在反应中检查支柱类型

在反应中检查支柱类型
EN

Stack Overflow用户
提问于 2016-12-07 20:46:43
回答 2查看 2.2K关注 0票数 4

我正在阅读官方React文档中的React.Component部分。除了零件关于propTypes之外,一切都是有意义的。docs声明如下:

在生产模式中,为了提高效率,跳过了propTypes检查。

假设我有以下代码:

代码语言:javascript
运行
复制
class Sample extends React.Component {
    render() {
        return (
            <div>Hello {this.props.name}</div>
        );
    }
}

Sample.propTypes = {
    name: React.PropTypes.string
};

这些文档是否意味着在生产中将跳过我对props的类型检查?如果是,我应该如何检查道具类型?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-12-07 20:53:28

你根本不检查自己的道具类型,反应为你做。

但是,正如文档所述,只有在您处于开发模式的情况下才行。每个支柱类型检查本质上是一个使用处理能力和内存的函数调用。

当你在开发的时候,知道你的一个道具有错误的类型,这是一个值得权衡的代价。

一旦投入生产,您的应用程序就应该经过足够彻底的测试,这样您的支柱类型验证就不会再失败了。

出于这个原因,它们被跳过以使您的应用程序更有效率。

票数 5
EN

Stack Overflow用户

发布于 2016-12-07 20:53:31

propTypes只用于验证当前的开发过程。当缺少某些必需的属性或属性的类型与预期的属性不匹配时,您将通过控制台日志得到通知。

没有必要在生产构建中验证这种类型的验证。缺少的属性不会破坏呈现过程,它们只是以意外的方式呈现组件。但是请注意,当您需要访问“给定”对象的属性时,您的呈现过程将失败。

要控制这种意外行为,您应该声明默认属性。

但是,强烈建议使用propTypes对象并使用单元测试来避免意外的呈现行为。坚持下去!

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

https://stackoverflow.com/questions/41027065

复制
相关文章

相似问题

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