- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我指的是这个 github project我正在尝试编写 KeyPad.js 的简单测试组件。
我已经看到关于这个问题的问题,一个建议的解决方案是将主题作为 prop 传递给组件。该溶液不适用于 enzyme 。
在我的案例中,问题是子组件通过 ThemeProvider 接收主题,并且为了能够进行测试,我需要向所有组件添加主题 Prop 。
例子:
const tree = renderer.create(
<KeyPad
theme={theme}
cancel={()=> true}
confirm={()=> true}
validation={()=> true}
keyValid={()=>true} />
).toJSON();
expect(tree).toMatchSnapshot();
KeyPad 的 render 方法会像这样改变,到处都是主题 Prop
render() {
let { displayRule, validation, label, confirm, cancel, theme, keyValid, dateFormat } = this.props
return (
<Container theme={theme}>
<Content theme={theme}>
<Header theme={theme}>
<CancelButton theme={theme} onClick={cancel}>
<MdCancel />
</CancelButton>
<Label>{label}</Label>
<ConfirmButton theme={theme} onClick={() => confirm(this.state.input)} disabled={!validation(this.state.input)}>
<MdCheck />
</ConfirmButton>
</Header>
<Display
theme={theme}
value={this.state.input}
displayRule={displayRule}
dateFormat={dateFormat}
cancel={this.cancelLastInsert} />
<Keys>
{[7, 8, 9, 4, 5, 6, 1, 2, 3, '-', 0, '.'].map( key => (
<Button
theme={theme}
key={`button-${key}`}
theme={theme}
click={(key) => this.handleClick(key) }
value={key}
disabled={!keyValid(this.state.input, key, dateFormat)} />
))}
</Keys>
</Content>
</Container>
)
}
我不喜欢这个解决方案。有人可以帮我解决这个问题吗?
谢谢
最佳答案
我只想解构回调的 props
参数并为 theme
添加一个默认值。这样,您可能从 theme
访问的任何 prop 都不会抛出 Cannot read property ... of undefined
并返回 undefined
。它会弄乱您的样式,但我认为您在单元测试中不会太在意它。
...
color: ${({ theme = {} }) => theme.background};
...
关于javascript - 使用样式化组件 themeProvider 开 Jest ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47401401/
我正在使用样式组件,我想知道是否有必要使用 ThemeProvider。 这是文档中的示例。 // Define our button, but with the use of props.theme
我正在项目中创建导航栏。在我的项目中,我使用 mui/图标 Material :^5.2.5 mui/ Material :^5.2.6 mui/样式:^5.2.3 现在我的文件夹结构是 根.jsx
我想知道哪里应该放在 React 应用程序中。 我想出了两个解决方案。 1、应该在顶级组件中使用“仅一次” 喜欢 index.js或 App.js由“create-react-app”工具创建的文件。
在使用 styled-components 时,如何访问 global.js 中的 ThemeProvider props ? 例如,在 theme.js 中,我有 ${props => props.
所以我正在为这家公司构建一个设计系统,组件系统在设计系统故事书中正确显示。但是当我将它导入消费者应用程序时,出现以下错误 TypeError: Cannot read property 'width'
我在我的 App.js 中创建了一个主题,它覆盖了主要颜色和次要颜色。我有 ThemeProvider 包装 Home 组件。覆盖的值未显示在 Home 组件中。我做错了什么? App.js impo
跟进 Github 上的问题,我有一个组件Comp导出时,用 injectSheet 包裹来自reactjss 。 请参阅 codesandbox 上的设置。 在单元测试中,我想断言该组件包含 ,它
我指的是这个 github project我正在尝试编写 KeyPad.js 的简单测试组件。 我已经看到关于这个问题的问题,一个建议的解决方案是将主题作为 prop 传递给组件。该溶液不适用于 en
我目前正在使用 nx.dev 作为 monorepo。我有多个 react 客户。多亏了 NX,我有了一个中央 Material Ui 配置(在 lib 文件夹内)。 我正在尝试在该 mui 文件夹中
所以我有这两个使用 MUI 的项目。其中一个只包含小的功能组件(一个库),另一个通过 yarn link 导入组件的“库”,并且应该通过“ThemeProvider”应用自定义主题。 我使用故事书作为
我正在尝试为暗模式和亮模式主题设置切换。在消除了项目中的几乎所有内容后,我设法在一个最小的示例中重现了该问题。 当我使用 React.StrictMode JSX 包装器,useful to prev
有没有办法使用 enzyme 浅方法和样式组件的 ThemeProvider 包装来测试样式组件的文本内容? class MyComponent extends React.component {
我经常使用 Material UI,所以这令人费解。我查看了文档,检查了我的代码,但看不到问题所在。我希望嵌套组件中的 H2 标签使用 Arial。但是,它是使用 Times 渲染的。我不确定为什么。
我有一个 styles.tsx 文件,因为我不想将样式放入我的组件中: //styles.tsx import {grey, purple} from '@mui/material/colors';
我有一个 styles.tsx 文件,因为我不想将样式放入我的组件中: //styles.tsx import {grey, purple} from '@mui/material/colors';
我正在尝试实现一个基本的 ThemeProvider与 StyledComponents。我已经毫无问题地基本使用了 styled-components,但是,在尝试实现 的使用时它不赞成我正在尝试
在将 StyledComponents 与 ThemeProvider 一起使用时,我无法获得正确的类型。 我已经用这种方法试过了: https://github.com/styled-compone
应用“ThemeProvider”标签时,我看不到任何变化,即使在如下所示的简单元素中也是如此。 浏览器控制台中没有错误/警告(未使用的导入除外,但即使我将它们全部删除也会失败)。 import Re
我越来越沮丧,因为过去几天我一直试图将我的 React 应用程序从 javascript 迁移到 tsx。到目前为止,我喜欢 tsx 的类型检查,但我不相信 Material-ui 库,尽管它解释了如
这里的问题很简单,真的。 我目前正在开发一个应用程序,我想将部分拆分为组件。 我决定创建一个样板来使用 rollupJS 创建模块,以便使用 NPM 将这些模块导出到我的核心应用程序中。 在我的依赖项
我是一名优秀的程序员,十分优秀!