首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >造型部件.动态样式

造型部件.动态样式
EN

Stack Overflow用户
提问于 2022-01-19 22:08:51
回答 1查看 660关注 0票数 0

我学习如何使用样式组件的反应,我做了一步一步的视频。我有这段代码,这行和其他代码都有问题

代码语言:javascript
复制
color: ${(props) => (props.invalid ? "red" : "black")} 

VS Code告诉我

'ThemedStyledProps、"key“、HTMLAttributes> &{. }、any>等类型可能不存在

”属性‘,您的意思是’onInvalid‘?ts(2568)

代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
import React, { useState } from "react";
import styled from "styled-components";
import Button from "../../UI/Button/Button";
import "./CourseInput.css";

const FormControl = styled.div`
  margin: 0.5rem 0;

  & label {
    font-weight: bold;
    display: block;
    margin-bottom: 0.5rem;
    color: ${(props) => (props.invalid ? "red" : "black")}
  }

  & input {
    display: block;
    width: 100%;
    border: 1px solid ${(props) => (props.invalid ? "red" : "#ccc")};
    background: ${(props) => (props.invalid ? "red" : "transparent")}
    font: inherit;
    line-height: 1.5rem;
    padding: 0 0.25rem;
  }

  & input:focus {
    outline: none;
    background: #fad0ec;
    border-color: #8b005d;
  }
`;

const CourseInput = (props) => {
  const [enteredValue, setEnteredValue] = useState("");
  const [isValid, setIsValid] = useState(true);

  const goalInputChangeHandler = (event) => {
    //set back true
    if (event.target.value.trim().length > 0) {
      setIsValid(true);
    }
    setEnteredValue(event.target.value);
  };

  const formSubmitHandler = (event) => {
    event.preventDefault();
    if (enteredValue.trim().length === 0) {
      //trim deletes white spacec overall
      setIsValid(false);
      return;
    }

    props.onAddGoal(enteredValue);
  };

  return (
    <form onSubmit={formSubmitHandler}>
      {/* <div className={`form-control ${!isValid ? "invalid" : ""}`}> */}
      <FormControl invalid={!isValid}>
        <label>Course Goal</label>
        <input type="text" onChange={goalInputChangeHandler} />
      </FormControl>
      {/* </div> */}
      <Button type="submit">Add Goal</Button>
    </form>
  );
};

export default CourseInput;

EN

回答 1

Stack Overflow用户

发布于 2022-01-21 13:00:16

由于无效不是div元素默认知道的支柱,因此它不会识别它。

要克服这一问题,您可以使用"$“键提供FormControl支持,如下所示:

代码语言:javascript
复制
<FormControl $invalid={!isValid}>

然后,在FormControl内部:

代码语言:javascript
复制
color: ${(props) => (props.$invalid ? "red" : "black")}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70778383

复制
相关文章

相似问题

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