【TS】object类型
2024-10-21 04:18:22
object
是一个对象,在ts
中定义对象类型的语法为:let 变量名 :object = { }
在object类型中,对象内部定义的值是不受类型约束的,只要是一个object类型即可,例如:
let obj : object = {
name : '艺术概论', // 字符串
price : 999 // 数字
}
console.log(obj); // {name: '艺术概论', price: 999}
object
类型在函数中的使用
// 定义一个函数,参数是object类型,返回值也是object类型
function getObj (obj:object) : object {
console.log(obj);
return {
name : '东方不败',
age : 100
}
}
定义object
类型,传入的值必须是object
类型,否则会报错
console.log(getObj({name : '孙悟空',age : 1000})); // 正确
// console.log(getObj(123)); // 错误的
某些方法本质是一个对象,所以也可以传入,比如 new String
console.log(getObj(new String('艺术概论'))); // 正确
打印 console.log(new String)
的话可以看到 string
是一个对象
new String为什么是一个对象?
通常定义字符串的方法有这些
let str = '东方不败' // 字符串
let str2 = String('东方不败') // 字符串
let str3 = new String('东方不败') // 对象 String{}
前两种方法是基础类型的,str
为直接定义基础字符串类型,str2
为String
方法转换值为字符串,本质还是一个基础类型字符串,str3
则为对象,为了验证结果,对这几个变量进行类型检测
// 检测类型
console.log(typeof str); // string
console.log(typeof str2); // string
console.log(typeof str3); // object
对象类型是可以直接 obj.xxx = xxx
来新增属性的
// str.name = '东方求败' // 报错 字符串无法 .name
// str2.name = '东方求败' // 报错 字符串无法 .name
str3.name = '东方求败' // 成功
str3
打印的结果
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
最新文章
- DependencyResolver.Current
- ACM/ICPC 之 靠墙走-DFS+BFS(POJ3083)
- 【BZOJ1911】[Apio2010]特别行动队 斜率优化DP
- 转: 深入理解Linux修改hostname
- Mondrian – 开源的矢量图形 Web 应用程序
- iOS - Mac Apache WebServer 服务器配置
- HDU1695 GCD(莫比乌斯反演)
- selenium+phantomJS学习使用记录
- 分布式文件系统--GFS
- POJ3041Asteroids(二分图最少顶点覆盖)
- NOTES : A Model of Gas Exchange for Hyperpolarized Xe(129) Magnetic Resonance of the Lung
- Live555 Streaming from a live source
- 网络编程(学习整理)---1--(Tcp)实现简单的控制台聊天室
- 【JSP】JSTL核心标签库的使用方法和示例
- ContentResolver + SqliteOpenHelper + ContentProvider 理解
- RESTful学习记录
- hdu 5078 Osu! (2014 acm 亚洲区域赛鞍山 I)
- 1024 Python 要诀
- Android Studio 使用入门
- log4j生成有日期的日志文件名
热门文章
- 第2-4-1章 规则引擎Drools介绍-业务规则管理系统-组件化-中台
- 关于解决linux python3安装gattlib报错
- Zabbix技术分享——使用Zabbix6.0监控业务日志
- 【SQL基础】多表查询:子查询、连接查询(JOIN)、组合查询(UNION集合运算)
- xshell+Xftp下载
- 零基础入门 Java 后端开发,有哪些值得看的视频?
- 【Redis场景2】缓存更新策略(双写一致)
- 用了这么多年的 SpringBoot 你知道什么是 SpringBoot 的 Web 类型推断吗?
- TS学习笔记
- 网络流棋盘模型 | P3355 骑士共存问题 P4304 [TJOI2013]攻击装置