簡(jiǎn)單聊聊TypeScript只讀修飾符
前言
在Typescript 2.0中,引入了readonly關(guān)鍵字,可以對(duì)類中的屬性進(jìn)行修飾,作用是:該屬性被readonly修飾之后無(wú)法修改**(如需修改,在構(gòu)造函數(shù)中可以對(duì)只讀屬性進(jìn)行修改)**。
我們可以直接在interface和type中直接使用readonly。
我們來(lái)看一個(gè)簡(jiǎn)單的例子:我們定義一個(gè)User type
type User={
readonly name : string;
readonly age : number
}我們可以創(chuàng)建一個(gè)user,并且初始化一個(gè)具體的值。
let user:User={
name:'搞前端的半夏',
age:18
}如果我們?nèi)バ薷腶ge的值,編譯器會(huì)直接報(bào)錯(cuò)。
user.age=19

只讀函數(shù)參數(shù)
在JS中,我們會(huì)經(jīng)常使用const來(lái)定義變量,但是const無(wú)法保證Object內(nèi)部的屬性不被改變。還是上面的User type,
我們有一個(gè)函數(shù)接受User type的參數(shù)。我們?cè)诤瘮?shù)內(nèi)部修改age屬性,編譯直接出錯(cuò)。
這樣的好處是:我們可以確定這里定義的全局user,無(wú)法被改變
let user:User={
name:'搞前端的半夏',
age:18
}
UserInfo(user)function UserInfo(user:User){
user.age=19
console.log(user.name,user.age)
}
如何更改函數(shù)
只讀類屬性
readonly修飾符還可以應(yīng)用在類中聲明的屬性。這里我們創(chuàng)建了一個(gè)User類,具有只讀的name和age,請(qǐng)注意這里的name和age是沒(méi)有初始值的。
class User {
readonly name: string;
readonly age: number;
constructor(name: string, age: number) {
this.name = name;
this.age = age;
}
UserInfo(user:User){
console.log(user.name,user.age)
}
}我們創(chuàng)建一個(gè)user實(shí)體,使用new方法創(chuàng)建對(duì)象的同時(shí),給name和age添加默認(rèn)值,由此可以得出結(jié)論
在類的constructor中,我們可以修改只讀屬性的值
name和age是只讀的,我們可以獲取具體的值。
let user =new User('搞前端的半夏',18)
console.log(user.name)
console.log(user.age)但是,如果嘗試修改name和age的值,會(huì)編譯出錯(cuò)。

我們嘗試在UserInfo中修改name和age:
UserInfo(user:User){
this.age=20
console.log(user.name,user.age)
}可以看到,編譯仍然是錯(cuò)誤的!我們可以得出結(jié)論
在類中的普通方法 無(wú)法 修改 被readonly的屬性

只讀索引
可以使用readonly來(lái)標(biāo)記索引。例如下面的ReadonlyArray,可以有效的防止給具體的索引分配具體的值。
interface ReadonlyArray<T> {
readonly length: number;
// ...
readonly [n: number]: T;
}因?yàn)槭侵蛔x的索引,所以下面的賦值操作,會(huì)編譯出錯(cuò)。
const readonlyArray: ReadonlyArray<number> = [2, 3, 5, 7]; readonlyArray[4] = 11;

總結(jié)
readonly是TS類型系統(tǒng)的一部分,它只是一個(gè)編譯時(shí)的工具,TypeScript 代碼被編譯為 JavaScript,所有的readonly都消失了。所以在運(yùn)行時(shí)沒(méi)有任何針對(duì)屬性只讀的保護(hù)。TS是通過(guò)編譯器來(lái)檢查并幫助你編寫(xiě)正確的代碼。
例如下面的示例,即使我們的編譯器提示有錯(cuò)誤,TS仍然可以編譯成對(duì)應(yīng)的JS代碼,這也完全說(shuō)明TS只是在編譯的階段,引導(dǎo)我們規(guī)范正確的編碼

到此這篇關(guān)于TypeScript只讀修飾符的文章就介紹到這了,更多相關(guān)TS只讀修飾符內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript實(shí)現(xiàn)帶下拉子菜單的導(dǎo)航菜單效果
這篇文章主要介紹了javascript實(shí)現(xiàn)帶下拉子菜單的導(dǎo)航菜單效果的方法,涉及javascript操作頁(yè)面元素與樣式的相關(guān)技巧,需要的朋友可以參考下2015-05-05
javascript解決IE6下hover問(wèn)題的方法
本文分享了一個(gè)小技巧:javascript解決IE6下hover問(wèn)題的方法,方法很實(shí)用,需要了解的朋友可以參考下2015-07-07
微信提示 在瀏覽器打開(kāi) 效果實(shí)現(xiàn)過(guò)程解析
這篇文章主要介紹了微信提示 在瀏覽器打開(kāi) 效果實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
JS點(diǎn)擊某個(gè)圖標(biāo)或按鈕彈出文件選擇框的實(shí)現(xiàn)代碼
本文給大家介紹js點(diǎn)擊點(diǎn)擊某個(gè)圖標(biāo)或按鈕彈出文件選擇框的實(shí)現(xiàn)代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),感興趣的朋友可以參考下2016-09-09
javascript實(shí)現(xiàn)數(shù)字時(shí)鐘效果
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)數(shù)字時(shí)鐘效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-02-02
js操作數(shù)組函數(shù)實(shí)例小結(jié)
這篇文章主要介紹了js操作數(shù)組函數(shù),實(shí)例分析了JavaScript針對(duì)數(shù)組刪除指定元素、去重及刪除指定下標(biāo)元素的實(shí)現(xiàn)方法,需要的朋友可以參考下2015-12-12
JavaScript實(shí)現(xiàn)簡(jiǎn)單表單驗(yàn)證案例
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單表單驗(yàn)證案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08

