【TS】object类型

object是一个对象,在 ts中定义对象类型的语法为: let 变量名 :object = { }
在object类型中,对象内部定义的值是不受类型约束的,只要是一个object类型即可,例如:

let obj : object = {
    name : '艺术概论',
    price : 999
}
console.log(obj);

object 类型在函数中的使用


function getObj (obj:object) : object {
    console.log(obj);
    return {
        name : '东方不败',
        age : 100
    }
}

定义 object类型,传入的值必须是 object类型,否则会报错

console.log(getObj({name : '孙悟空',age : 1000}));

某些方法本质是一个对象,所以也可以传入,比如 new String

console.log(getObj(new String('艺术概论')));

打印 console.log(new String) 的话可以看到 string是一个对象

【TS】object类型

new String为什么是一个对象?

通常定义字符串的方法有这些

let str = '东方不败'
let str2 = String('东方不败')
let str3 = new String('东方不败')

前两种方法是基础类型的, str为直接定义基础字符串类型, str2String方法转换值为字符串,本质还是一个基础类型字符串, str3则为对象,为了验证结果,对这几个变量进行类型检测


console.log(typeof str);
console.log(typeof str2);
console.log(typeof str3);

【TS】object类型
对象类型是可以直接 obj.xxx = xxx 来新增属性的

str3.name = '东方求败'

str3打印的结果

【TS】object类型

js中变量存储有两种方式

1、基础类型存储 : String , Boolean , Number , Undefined , Null
2、引用类型存储 : Object(Array,Date,RegExp,Function)

  • js的定义的变量都是保存在堆和栈中的
  • 基础类型保存在栈内存中,值与值之间独立存在,互补干扰,因此不存在修改了一个变量导致原始变量值发生改变的问题。
  • 对象类型保存在堆中,创建对象会在堆内存中开辟一个新空间,变量保存的是对象的内存地址,而不是保存的值,也就是栈(变量)中存的是堆的指针,如果两个变量保存的是同一个地址,那么他们的指针指向的是同一个,所以通过 a变量修改属性时, b变量也会受到影响。
  • 两个基础类型的数据比较时,比较的是值。
  • 两个引用类型的数据比较时,比较的是内存地址,如果两个变量一模一样,但是内存地址不同,也会返回 false

在此处 str3中, new String() 实际上是创建了一个新的对象,将值存到了实例对象的堆中,所以我们可以给 str3添加属性。

案例源码:https://gitee.com/wang_fan_w/ts-seminar

如果觉得这篇文章对你有帮助,欢迎点亮star

Original: https://blog.csdn.net/qq_44793507/article/details/127823585
Author: fanction
Title: 【TS】object类型

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/660874/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球