admin管理员组文章数量:1345088
I'm trying to convert a react project into TypeScript. The code below is an input field that counts how many characters that is being inputed.
In the renderCharactersLeft function I get the following error:
This doesn't really surprise me since the default state 'charsLeft' is set to null, but I wonder how you would bypass or solve this message in TypeScript?
import React from "react";
interface CharCountInputProps {
value: string;
type: string;
name: string;
maxChars: number;
onChange: any;
}
interface CharCountInputState {}
class CharCountInput extends React.Component<
CharCountInputProps,
CharCountInputState
> {
state = {
charsLeft: null
};
ponentDidMount() {
this.handleCharCount(this.props.value);
}
handleCharCount = (value: string) => {
console.log(value);
const { maxChars } = this.props;
const charCount = value.length;
const charsLeft = maxChars - charCount;
this.setState({ charsLeft });
};
changeHandler = (event: React.ChangeEvent<HTMLInputElement>) => {
this.setState({ [event.target.name]: event.target.value } as Pick<
CharCountInputState,
keyof CharCountInputState
>);
this.handleCharCount(event.target.value);
this.props.onChange(event);
};
renderCharactersLeft = () => {
const { charsLeft } = this.state;
let content;
if (charsLeft >= 0) {
content = <span>{`characters left: ${charsLeft}`}</span>;
} else if (charsLeft != null && charsLeft < 0) {
const string = charsLeft.toString().substring(1);
content = <span>{`too many characters: ${string}`}</span>;
} else {
content = null;
}
return content;
};
render() {
const { value, type, name } = this.props;
return (
<>
<input
onChange={this.changeHandler}
value={value}
type={type}
name={name}
/>
{this.renderCharactersLeft()}
</>
);
}
}
export default CharCountInput;
I'm trying to convert a react project into TypeScript. The code below is an input field that counts how many characters that is being inputed.
In the renderCharactersLeft function I get the following error:
This doesn't really surprise me since the default state 'charsLeft' is set to null, but I wonder how you would bypass or solve this message in TypeScript?
import React from "react";
interface CharCountInputProps {
value: string;
type: string;
name: string;
maxChars: number;
onChange: any;
}
interface CharCountInputState {}
class CharCountInput extends React.Component<
CharCountInputProps,
CharCountInputState
> {
state = {
charsLeft: null
};
ponentDidMount() {
this.handleCharCount(this.props.value);
}
handleCharCount = (value: string) => {
console.log(value);
const { maxChars } = this.props;
const charCount = value.length;
const charsLeft = maxChars - charCount;
this.setState({ charsLeft });
};
changeHandler = (event: React.ChangeEvent<HTMLInputElement>) => {
this.setState({ [event.target.name]: event.target.value } as Pick<
CharCountInputState,
keyof CharCountInputState
>);
this.handleCharCount(event.target.value);
this.props.onChange(event);
};
renderCharactersLeft = () => {
const { charsLeft } = this.state;
let content;
if (charsLeft >= 0) {
content = <span>{`characters left: ${charsLeft}`}</span>;
} else if (charsLeft != null && charsLeft < 0) {
const string = charsLeft.toString().substring(1);
content = <span>{`too many characters: ${string}`}</span>;
} else {
content = null;
}
return content;
};
render() {
const { value, type, name } = this.props;
return (
<>
<input
onChange={this.changeHandler}
value={value}
type={type}
name={name}
/>
{this.renderCharactersLeft()}
</>
);
}
}
export default CharCountInput;
Share
Improve this question
edited Dec 10, 2019 at 14:47
Dupocas
21.4k7 gold badges41 silver badges57 bronze badges
asked Dec 10, 2019 at 14:46
erikos93erikos93
6872 gold badges13 silver badges28 bronze badges
6
-
cant you do something like
charsLeft && charsLeft >= 0
– Rohan Bhangui Commented Dec 10, 2019 at 14:51 - Hmm yeah I tried that. Then I get the error on the next charsLeft after the && (charsLeft >= 0) – erikos93 Commented Dec 10, 2019 at 14:55
-
1
What's the reasoning behind the initial state of
charsLeft
being null? Would an initial state of0
be more appropriate? – kschaer Commented Dec 10, 2019 at 14:55 - Whats the error you get when you add that line? – Rohan Bhangui Commented Dec 10, 2019 at 14:56
-
2
Is
null
required? can't you set it tothis.props.maxChars
initially? – Jai Commented Dec 10, 2019 at 14:56
2 Answers
Reset to default 9You could add a null check to your if-statement like this:
if (charsLeft !== null && charsLeft >= 0) {
or alternatively set the initial state for charsLeft to something other than null (ex. maxChars from your props)
Another alternative is You can create local variable and assign the charLeft to it and use the local variable for pare.
let newVariable = charLeft;
if(newVariable > 0) {
//do coding
}
本文标签: javascriptTypeScript Object is possibly 39null39Stack Overflow
版权声明:本文标题:javascript - TypeScript: Object is possibly 'null' - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743784967a2538519.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论