javascript - react 中出现警告 : Received `false` for a non-boolean attribute `border` .?

标签 javascript reactjs react-hooks styled-components

我。我的状态低于警告。我不知道我哪里做错了。我在演示应用程序中使用样式组件。

react_devtools_backend.js:4061 Warning: Received `false` for a non-boolean attribute `border`.

If you want to write it to the DOM, pass a string instead: border="false" or border={value.toString()}.

If you used to conditionally omit it with border={condition && value}, pass border={condition ? value : undefined} instead.

我很喜欢这个。我创建了一个这样的组件。我还添加了一些控制台来调试。这是我的调试语句

 console.log('========',depth,depth === 1);

调试语句输出 ======== 3 错误

5MobileHeader.tsx:63 ======== 4 false
MobileHeader.tsx:63 ======== 3 false
3MobileHeader.tsx:63 ======== 4 false

组件调用

组件定义

interface CardHeaderProps {
  border: boolean;
}

export const CardHeader = styled(Card.Header)<CardHeaderProps>`
  background-color: transparent;
  border-radius: 0 !important;
  border: 0;
  padding: 10px 20px;

  ${props =>
    props.border &&
    css`
      border-bottom: 1px solid #dad8d8;
    `}
`;

最佳答案

您可以做两件事。

  1. 不要将 border 属性转发到 Card.Header,因为 Card.Header 没有 border 属性,并且会将 border 属性转发到底层 div 也不支持 border 属性。如果不是 border,请使用 shouldForwardProp 选项和forward prop。

https://styled-components.com/docs/api#shouldforwardprop (如果您使用 mui 风格也适用)

   export const CardHeader = styled(Card.Header, { shouldForwardProp: (prop)=> prop !== 'border'})<CardHeaderProps>`
        background-color: transparent;
        border-radius: 0 !important;
        border: 0;
        padding: 10px 20px;
        border-bottom: ${(props) => props.border ? '1px solid #dad8d8' : 'none'};
    `;
  • 如果您不想使用 shouldForwardProp(您应该使用它,请参阅上面的链接),则使用

     <CardHeader border={depth === 1 ? 1 : 0}> // instead of true/false. When u inspect the element you will see the border prop after rendering.
    
  • 更简洁的代码

    export const CardHeader = styled(Card.Header, { shouldForwardProp: (prop)=> prop !== 'border'})(({ theme, border })`
        border-bottom: ${border ? 'some code' : 'none'};
    
    `)
    

    关于javascript - react 中出现警告 : Received `false` for a non-boolean attribute `border` .?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71008864/

    相关文章:

    javascript - 这些代码是不可变的吗?

    javascript - 持续的 JavaScript 测试

    node.js - "npm run build --prod"中的 --prod 标志有什么用?

    javascript - React Hooks 和 UseEffect 不使用 socketIO 数据更新显示。只渲染数组中的元素

    reactjs - React hooks - 如何测试多个 useState hooks

    javascript - Sharepoint 2013 托管应用程序在所有加载的页面上执行 javascript

    javascript - 使用 querySelector 进行事件冒泡

    javascript - React 异步数据(对象)在分配给状态时被损坏

    javascript - 密码确认和密码相同,但验证仍然触发 React 组件中的 JOI

    javascript - 重新渲染时 react 自定义 Hook 状态不更新