Null value type checking
P粉896751037
P粉896751037 2023-08-03 11:34:29
0
1
534
<p>I just wrote a method in a service, but I'm running into an issue where the type hints that I might be returning a null value, even though I've done a null check in the if statement block. </p> <pre class="brush:php;toolbar:false;">public async getUserById(id: string): Promise<UserEntity> { const user = this.userRepository.getById(id); // returns <UserEntity | null> if (!user) { // checking for null throw new NotFoundUser(`Not found user`); } // Type 'UserEntity | null' is not assignable to type 'UserEntity'. // Type 'null' is not assignable to type 'UserEntity'. return user; }</pre> <p>I want to throw an exception if the user variable is empty and return the UserEntity if not. <br /><br />If I put two exclamation points there, the problem is solved. </p><p><br /></p> <pre class="brush:php;toolbar:false;">if (!!user) { // checking for null throw new NotFoundUser(`Not found user`); }</pre> <p>But if I type !!null in the console it will return false, so in this case I never get into a situation where an exception is thrown. Why does this behavior occur? </p>
P粉896751037
P粉896751037

reply all(1)
P粉267791326

Because !! is similar to Boolean, so in this line of code, you do something similar to Boolean(null), so you will get false, because in Boolean value, null is false. You can use user === null to check if it is null.

Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template