首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >有没有办法将默认值设置为prop,它是所需prop的子级?

有没有办法将默认值设置为prop,它是所需prop的子级?
EN

Stack Overflow用户
提问于 2019-09-05 19:08:23
回答 1查看 607关注 0票数 0

我想将默认值设置为size prop,但它是required prop的子级,所以我得到了错误。除了在eslint中禁用规则之外,还有其他解决方法吗?

代码语言:javascript
复制
static propTypes = {
        widget: PropTypes.shape({
            config: PropTypes.shape({
                size: PropTypes.string
            }).isRequired
        }).isRequired,
    };
代码语言:javascript
复制
static defaultProps = {
        widget: PropTypes.shape({
            config: PropTypes.shape({
                size: 's'
            })
        })
    }

Eslint错误

代码语言:javascript
复制
defaultProp "widget" defined for isRequired propType.eslint(react/default-props-match-prop-types)
EN

回答 1

Stack Overflow用户

发布于 2019-09-05 19:18:06

第一次观察,您可以简单地设置默认值,如下所示:

代码语言:javascript
复制
widget: {
config: {size: 's'}
}

其次,根据错误,没有为必填字段设置缺省值的点,因为当调用者未通过defaultProps提供缺省值时,将且必须设置缺省值

因此,可以将widget propTypes设置为optional,这样错误就不会出现,但是当通过props传入无效的形状时,形状将保持不变

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

https://stackoverflow.com/questions/57804142

复制
相关文章

相似问题

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