TypeScript5.2引入新關鍵字using介紹
TypeScript新關鍵字
TypeScript 5.2將引入一個新的關鍵字:using。當它離開作用域時,你可以用Symbol.dispose函數(shù)來處置任何東西。
{
const getResource = () => {
return {
[Symbol.dispose]: () => {
console.log('Hooray!')
}
}
}
using resource = getResource();
} // 'Hooray!' logged to console這是基于TC39提議,該提議最近達到了第三階段,表明它即將進入JavaScript。
using將對管理文件句柄、數(shù)據(jù)庫連接等資源非常有用。
Symbol.dispose
Symbol.dispose是JavaScript中一個新的全局symbol。任何具有分配給Symbol.dispose函數(shù)的東西都將被視為"資源":也就是具有特定生命周期的對象。并且該資源可以使用using關鍵字。
const resource = {
[Symbol.dispose]: () => {
console.log("Hooray!");
},
};await using
你也可以使用Symbol.asyncDispose和await來處理那些需要異步處置的資源。
const getResource = () => ({
[Symbol.asyncDispose]: async () => {
await someAsyncFunc();
},
});
{
await using resource = getResource();
}這將在繼續(xù)之前等待Symbol.asyncDispose函數(shù)。
這對數(shù)據(jù)庫連接等資源來說很有用,你要確保在程序繼續(xù)前關閉連接。
使用案例
文件句柄
通過節(jié)點中的文件處理程序訪問文件系統(tǒng),使用using可能會容易得多。
不使用using:
import { open } from "node:fs/promises";
let filehandle;
try {
filehandle = await open("thefile.txt", "r");
} finally {
await filehandle?.close();
}使用using:
import { open } from "node:fs/promises";
const getFileHandle = async (path: string) => {
const filehandle = await open(path, "r");
return {
filehandle,
[Symbol.asyncDispose]: async () => {
await filehandle.close();
},
};
};
{
await using file = getFileHandle("thefile.txt");
// Do stuff with file.filehandle
} // Automatically disposed!數(shù)據(jù)庫連接
管理數(shù)據(jù)庫連接是在C#中使用using的一個常見用例。
不使用using:
const connection = await getDb();
try {
// Do stuff with connection
} finally {
await connection.close();
}使用using:
const getConnection = async () => {
const connection = await getDb();
return {
connection,
[Symbol.asyncDispose]: async () => {
await connection.close();
},
};
};
{
await using { connection } = getConnection();
// Do stuff with connection
} // Automatically closed!圖片示例
下圖是上面示例的圖片版本:

總結
本文簡要介紹了TypeScript5.2中引入的新關鍵字using,它的出現(xiàn)可以很好的和Symbol.dispose搭配使用。有了它我們便不需要在try…catch語句中進行數(shù)據(jù)庫的關閉,這對管理文件句柄、數(shù)據(jù)庫連接等資源時非常有用。
更多關于TypeScript新關鍵字的資料請關注腳本之家其它相關文章!
相關文章
微信小程序實現(xiàn)拖拽 image 觸摸事件監(jiān)聽的實例
這篇文章主要介紹了微信小程序實現(xiàn)拖拽 image 觸摸事件監(jiān)聽的實例的相關資料,這里提供image觸摸并監(jiān)聽的簡單實例,需要的朋友可以參考下2017-08-08
mitt tiny-emitter發(fā)布訂閱應用場景源碼解析
這篇文章主要為大家介紹了mitt tiny-emitter發(fā)布訂閱應用場景源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
詳解微信小程序如何實現(xiàn)類似ChatGPT的流式傳輸
這篇文章主要為大家介紹了微信小程序如何實現(xiàn)類似ChatGPT的流式傳輸示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03

