TypeScript 中的感嘆號
Shuvayan Ghosh Dastidar
2023年10月8日
TypeScript
TypeScript Operator
TypeScript 是一種強型別語言,支援建立使用者定義型別和本機型別。除了型別之外,還有 null 和 undefined,它們確定變數中是否有意或無意缺少值。
如果將 null 值分配給型別化變數,TypeScript 會報錯。這是感嘆號或砰砰聲或!運算子用於強制編譯器將值解釋為非空值。
本教程將重點介紹如何使用!運算子。
在 TypeScript 中使用 !斷言非 Null 的運算子
這 !運算子可以強制編譯器將值斷言為非 null 或非 undefined,儘管值型別可能為 null 或者是型別的聯合,其中 null 是其中一種型別。當使用者知道該值永遠不會為 null 時,這是由使用者完成的。
這 !運算子是在轉編譯為 JavaScript 時刪除的 TypeScript 語法。它可以被認為是類似的斷言運算子,如 as。
以下基本示例將顯示!可以使用。
function getValue() : number | undefined {
return 3;
}
var realValue : number | undefined;
realValue = getValue();
var value : number;
value = realValue!;
console.log(value);
輸出:
3
getValue() 函式可能是一個繁重的計算呼叫,但始終確保返回一個 number 型別。沒有!運算子,TypeScript 將顯示諸如 Type 'number | undefined' is not assignable to type 'number'。
!運算子強制編譯器將該值斷言為非空,並且以後不再丟擲錯誤。
! 的示例用法 TypeScript 中的運算子
! 的示例可以使用的運算子在程式碼段中給出。
interface Fruit {
code : string;
fruit : string;
}
const fruits : Fruit[] = [
{
code : "ORA",
fruit : "Orange"
},
{
code : "APL",
fruit : "Apple"
},
{
code : "GRA",
fruit : "Grapes"
},
{
code : "LITC",
fruit : "Litchi"
}
]
const findFruit = ( fruitToFilter : string ) => {
return fruits.find( fruit => fruit.code === fruitToFilter);
}
const fruit : Fruit = findFruit("APL")!;
console.log(fruit);
輸出:
{
"code": "APL",
"fruit": "Apple"
}
find 操作返回型別 string | undefined。編譯器被迫將其視為字串而不考慮 undefined,因為使用者確定返回的值不會是 undefined。
TypeScript 中!操作符的有害影響
使用者提供!運算子並強制編譯器將該值視為非 null。如果返回的值是 undefined 或 null,編譯器將不會捕獲任何錯誤,並且應用程式可能會面臨執行時錯誤。
所以 !應避免使用運算子,僅在保證返回的值不會為 null 或 undefined 時使用。
Enjoying our tutorials? Subscribe to DelftStack on YouTube to support us in creating more high-quality video guides. Subscribe
