您现在的位置是:群英 > 开发技术 > web开发
TypeScript中的用法只读修饰符怎样用
Admin发表于 2022-05-26 17:25:29893 次浏览
今天这篇给大家分享的知识是“TypeScript中的用法只读修饰符怎样用”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“TypeScript中的用法只读修饰符怎样用”文章能帮助大家解决问题。

前言

在typescript 2.0中,引入了readonly关键字,可以对类中的属性进行修饰,作用是:该属性被readonly修饰之后无法修改**(如需修改,在构造函数中可以对只读属性进行修改)**。

我们可以直接在interfacetype中直接使用readonly。

我们来看一个简单的例子:我们定义一个user type

type user={
   readonly  name : string;
   readonly  age  : number
}

我们可以创建一个user,并且初始化一个具体的值。

let user:user={
    name:'搞前端的半夏',
    age:18
}

如果我们去修改age的值,编译器会直接报错。

user.age=19

只读函数参数

在js中,我们会经常使用const来定义变量,但是const无法保证object内部的属性不被改变。还是上面的user type,

我们有一个函数接受user type的参数。我们在函数内部修改age属性,编译直接出错。

这样的好处是:我们可以确定这里定义的全局user,无法被改变

let user:user={
    name:'搞前端的半夏',
    age:18
}
userinfo(user)
function userinfo(user:user){
    user.age=19
    console.log(user.name,user.age)
}

如何更改函数

只读类属性

readonly修饰符还可以应用在类中声明的属性。这里我们创建了一个user类,具有只读的name和age,请注意这里的name和age是没有初始值的。

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)
    }
}

我们创建一个user实体,使用new方法创建对象的同时,给name和age添加默认值,由此可以得出结论

在类的constructor中,我们可以修改只读属性的值

name和age是只读的,我们可以获取具体的值。

let user =new user('搞前端的半夏',18)

console.log(user.name)
console.log(user.age)

但是,如果尝试修改name和age的值,会编译出错。

我们尝试在userinfo中修改name和age:

   userinfo(user:user){
        this.age=20
        console.log(user.name,user.age)
    }

可以看到,编译仍然是错误的!我们可以得出结论

在类中的普通方法 无法 修改 被readonly的属性

只读索引

可以使用readonly来标记索引。例如下面的readonlyarray,可以有效的防止给具体的索引分配具体的值。

interface readonlyarray<t> {
  readonly length: number;
  // ...
  readonly [n: number]: t;
}

因为是只读的索引,所以下面的赋值操作,会编译出错。

const readonlyarray: readonlyarray<number> = [2, 3, 5, 7];
readonlyarray[4] = 11;

总结

readonly是ts类型系统的一部分,它只是一个编译时的工具,typescript 代码被编译为 javascript,所有的readonly都消失了。所以在运行时没有任何针对属性只读的保护。ts是通过编译器来检查并帮助你编写正确的代码。

例如下面的示例,即使我们的编译器提示有错误,ts仍然可以编译成对应的js代码,这也完全说明ts只是在编译的阶段,引导我们规范正确的编码



以上就是关于“TypeScript中的用法只读修饰符怎样用”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

相关信息推荐
2022-05-11 12:01:36 
摘要:这篇文章主要介绍了php优化查询foreach代码实例讲解,列举了代码实例和测试结果,有感兴趣的同学可以学习下
2022-09-05 17:28:01 
摘要:实现超级链接的标记是“<a>”。a标签可以定义超链接,用于从一张页面链接到另一张页面,语法“<a href="指向的页面的URL">超链接文本</a>”;a标签中最重要的属性是href,它用于指示链接目标,不可省略,否则会失去链接功能。
2022-05-28 17:11:14 
摘要:java报错信息在页面显示的方法:首先自定义异常类;然后在service层的抛出异常类,controller类继承主异常类;接着定义的主异常类,里面可以写多个自己定义的异常类;最后完成信息类代码。
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部