TypeScript 学习笔记(四)
函数:
1、函数是一组一起执行一个任务的语句
2、我们可以把一段可复用的代码放到一起组成函数,从而提高效率
3、函数声明(通过关键字 function 来声明)告诉编译器函数的名称、返回类型和参数
4、函数定义提供了函数的实际主体,在这里函数体由花括号括起来
5、函数有可选参数、默认参数和剩余参数等,可选参数由 "?" 号标识,默认参数则是提供默认值,
在不知道有几个参数的时候我们使用剩余参数,前面由 "..." 标识
function setNum(num?: number) {
let theNum = ;
// num 为可选参数
if (num)
theNum = num;
return theNum;
}
function greet(firstName: string, lastName: string = "Yam") {
// lastName 为默认参数
return "Hello " + firstName + " " + lastName;
}
// 剩余参数 sumArr
function add(...sumArr: number[]) {
let sum: number = ;
for (let i = ; i < sumArr.length; ++i)
sum += sumArr[i];
return sum;
}
let getNum: number = setNum();
let hello = greet("Lemon");
let getSum = add(, , );
let str: string = `${getNum}
${hello}
${getSum}`;
// 弹出 12
// HelloHello Lemon Yam
//
alert(str);
注:参数不能同时设为可选的和默认的
6、匿名函数是一个没有函数名的函数,我们可以赋值给一个变量,从而形成函数表达式
let func = function([args]) {...}
7、函数通过在函数后使用 "()" 实现自调用
// 赋值给 sayHello 后自调用
let sayHello = function () {
alert("Hello World");
}()
8、Lambda 函数也称箭头函数
// 格式为 ([param1, param2, ..., paramn]) => statement;
let greet = (name: string) => {alert(`Hello ${name}`);}
9、函数重载:方法名字相同而参数不同,返回类型1可以相同也可以不同
function disp(str: string) {
console.log(str);
}
function disp(num: number) {
console.log(num);
}
disp("Lemon");
disp(12);
Number:
1、对象属性:
a、MAX_VALUE:可表示的最大的数
b、MIN_VALUE:可表示的最小的数
c、NaN:非数字值
d、POSITIVE_INFINITY:正无穷大,溢出时返回该值,且该值大于 MAX_VALUE
e、NEGATIVE_INFINITY:负无穷大,溢出时返回该值,且该值小于 MIN_VALUE
f、prototype:Number 对象的静态属性,可通过它来向对象添加属性和方法
g、constructor:返回对创建此对象的 Number 函数引用
console.log("最大值" + Number.MAX_VALUE); // 最大值1.7976931348623157e+308
console.log("最小值" + Number.MIN_VALUE); // 最小值5e-324
console.log("非数字值" + Number.NaN); // 非数字值NaN
console.log("正无穷大" + Number.POSITIVE_INFINITY); // 正无穷大Infinity
console.log("负无穷大" + Number.NEGATIVE_INFINITY); // 负无穷大-Infinity
function Person(id: number, name: string) {
this.id = id;
this.name = name;
}
let student = new Person(11, "Lemon");
Person.prototype.habbit = "basketball";
console.log("学号:" + student.id); // 学号:11
console.log("名字:" + student.name); // 名字:Lemon
console.log("爱好:" + student.habbit); // 爱好:basketball
console.log("函数名字:" + student.constructor.name); // 函数名字:Person
2、对象方法:
a、toExponential():把对象的值转换为指数计数法
b、toFixed():把数字转换为字符串,并对小数点指定位数
c、toLocaleString():把数字转换为字符串,使用本地数字格式顺序
d、toPrecision():把数字格式化为指定的长度
e、toString():把数字转换为字符串,使用指定的基数(2~36 之间,默认为 10)
f、valueOf():返回一个 Number 对象的原始数字值
let num: number = 12.345;
// 12.345 的指数形式为:1.2345e+1
console.log("12.345 的指数形式为:" + num.toExponential());
// 12.345 保留小数点后 2 位后的字符串为:12.35
console.log("12.345 保留小数点后 2 位后的字符串为:" + num.toFixed(2));
// 转换成本地字符串12.345
console.log("转换成本地字符串" + num.toLocaleString());
// 指定长度为3后为:12.3
console.log("指定长度为3后为:" + num.toPrecision(3));
num = 16;
// 16 转换成 8 进制后的字符串为:20
console.log("16 转换成 8 进制后的字符串为:" + num.toString(8));
// 原始数字值16
console.log("原始数字值" + num.valueOf());
TypeScript 学习笔记(四)的更多相关文章
- Typescript 学习笔记四:回忆ES5 中的类
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记七:泛型
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记六:接口
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记五:类
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记二:数据类型
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记三:函数
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Typescript 学习笔记一:介绍、安装、编译
前言 整理了一下 Typescript 的学习笔记,方便后期遗忘某个知识点的时候,快速回忆. 为了避免凌乱,用 gitbook 结合 marketdown 整理的. github地址是:ts-gitb ...
- C#可扩展编程之MEF学习笔记(四):见证奇迹的时刻
前面三篇讲了MEF的基础和基本到导入导出方法,下面就是见证MEF真正魅力所在的时刻.如果没有看过前面的文章,请到我的博客首页查看. 前面我们都是在一个项目中写了一个类来测试的,但实际开发中,我们往往要 ...
- IOS学习笔记(四)之UITextField和UITextView控件学习
IOS学习笔记(四)之UITextField和UITextView控件学习(博客地址:http://blog.csdn.net/developer_jiangqq) Author:hmjiangqq ...
- java之jvm学习笔记四(安全管理器)
java之jvm学习笔记四(安全管理器) 前面已经简述了java的安全模型的两个组成部分(类装载器,class文件校验器),接下来学习的是java安全模型的另外一个重要组成部分安全管理器. 安全管理器 ...
随机推荐
- 常用的数据压缩lib
最近项目需要使用数据压缩,下面针对数据压缩库进行调研,并进行简单记录,对于关于库的介绍,可以在官网阅读最新的文档,我就不在这里重复了: A fast compressor/decompressor: ...
- 精通awk系列(13):print、printf、sprintf和重定向
回到: Linux系列文章 Shell系列文章 Awk系列文章 输出操作 awk可以通过print.printf将数据输出到标准输出或重定向到文件. print print elem1,elem2,e ...
- ZKWeb网页框架2.2.1正式发布
2.2.1 更新的内容有 改进 EFCore 支持 支持自动 json 序列化字段 (通过 WithSerialization 选项) 支持懒加载 更新后 EFCore 可以使用所有默认插件 (ZKW ...
- 50道Redis面试题史上最全,以后面试再也不怕问Redis了
1.什么是Redis? Redis本质上是一个Key-Value类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到硬盘上进行保存. ...
- Azure上的时序见解,Time series insights
5G来了,广连接(mmTC)可以实现每平方千米100万的连接数(理论值),是4G的10倍,5G网络出现,配合其他技术,空间将在数据意义上剧烈压缩,车联网.智能家居.智能安防.智慧工厂.智慧能源都可能带 ...
- Elasticsearch系列---初识Elasticsearch
Elasticsearch是什么? Elasticsearch简称ES,是一个基于Lucene构建的开源.分布式.Restful接口的全文搜索引擎,还是一个分布式文档数据库.天生就是分布式.高可用.可 ...
- Dubbo学习系列之十二(Quartz任务调度)
Quartz词义为"石英"水晶,然后聪明的人类利用它发明了石英手表,因石英晶体在受到电流影响时,它会产生规律的振动,于是,这种时间上的规律,也被应用到了软件界,来命名了一款任务调度 ...
- 精通awk系列(1):安装新版本的gawk
回到: Linux系列文章 Shell系列文章 Awk系列文章 安装新版本gawk awk有很多种版本,例如nawk.gawk.gawk是GNU awk,它的功能很丰富. 本教程采用的是gawk 4. ...
- Apply Grouping to List View Data 将分组应用于列表视图数据
This lesson will teach you how to apply grouping to List View data. For this purpose, you will group ...
- fiddler教程:抓包带锁的怎么办?HTTPS抓包介绍。
点击上方↑↑↑蓝字[协议分析与还原]关注我们 " 介绍Fiddler的HTTPS抓包功能." 这里首先回答下标题中的疑问,fiddler抓包带锁的原因是HTTPS流量抓包功能开启, ...