TypeScript应用 极速上手(7)

1、函数作为“一等公民”

主要体现在:

  • 变量类型可以是函数
  • 值(literal)可以是函数
  • 对象字段可以是函数
  • 函数的参数可以是函数
  • 函数的返回值可以是函数

2、实例



let a =  [3,5,8,9,7,6,12,35,18,78,11]
//  变量类型可以是函数 = literal 是函数
// let compareNumber = function(a:number,b:number){
//     return a-b
// }


//推荐使用箭头函数(lambda表达式)
let compareNumber = (a:number,b:number) => a-b
//函数的参数是函数
a.sort(compareNumber)
console.log(a) //[3, 5, 6, 7, 8, 9, 11, 12, 18, 35, 78] 

// compareNumber = function(a:number,b:number){
//     return b-a
// }
//推荐使用箭头函数(lambda表达式)
compareNumber = (a:number,b:number) => b-a

//函数的参数是函数
a.sort(compareNumber)
//匿名
a.sort((a:number,b:number) => a-b)


//箭头函数中,可以填写语句
a.sort((a:number,b:number) => {
    //其他语句...
    return a-b
})
//可以根据数组类型,让编译器推断参数类型(推荐)
a.sort((a,b) => {
    console.log('comparing',a,b)
    return a-b
})
console.log(a) //[3, 5, 6, 7, 8, 9, 11, 12, 18, 35, 78] 

//对象的字段是函数
const emp1 = {
    name:'james',
    salary:10000,
    increaseSalary:function(p:number){
        this.salary *= p 
    }
}

emp1.increaseSalary(1.5)
console.log(emp1)
//输出结果:
// {
//   "name": "james",
//   "salary": 15000
// } 


//函数的返回值可以是函数
function createComparer(){
    return (a:number,b:number) => a-b
}
let b = [1,3,5,69,12,34,55,13,9]
b.sort(createComparer())

//高阶函数
function createComparer1(p:{smallerFirst:boolean}){
    if(p.smallerFirst){
        return (a:number,b:number) => a-b
    }else{
        return (a:number,b:number) => b-a
    }
}

let c = [1,3,5,69,12,34,55,13,9]
c.sort(createComparer1({smallerFirst:true}))
console.log(c) //[1, 3, 5, 9, 12, 13, 34, 55, 69] 

  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DreamCatcher

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值