Typescript 函数

简介: typeScript中的函数

/*
1、vscode配置自动编译

1.第一步   tsc --inti 生成tsconfig.json   改 "outDir": "./js",  


2、第二步 任务 - 运行任务  监视tsconfig.json

2、typeScript中的数据类型

typescript中为了使编写的代码更规范,更有利于维护,增加了类型校验,在typescript中主要给我们提供了以下数据类型


    布尔类型(boolean)
    数字类型(number)
    字符串类型(string)
    数组类型(array)
    元组类型(tuple)
    枚举类型(enum)
    
    任意类型(any)
    null 和 undefined
    void类型
    never类型

3、typeScript中的函数

3.1、函数的定义
3.2、可选参数
3.3、默认参数
3.4、剩余参数
3.5、函数重载
3.6、箭头函数  es6

*/

// 3.1、函数的定义

//es5定义函数的方法
/*

//函数声明法
    function run(){

        return 'run';
    }
//匿名函数
    var run2=function(){

        return 'run2';
    }

*/

//ts中定义函数的方法

//函数声明法

    // function run():string{

    //     return 'run';
    // }


    //错误写法
    // function run():string{

    //     return 123;
    // }





//匿名函数

// var fun2=function():number{

//     return 123;
// }


// alert(fun2()); /*调用方法*/




//ts中定义方法传参

/*
    function getInfo(name:string,age:number):string{

            return `${name} --- ${age}`;
    }


    alert(getInfo('zhangsan',20));

*/


// var getInfo=function(name:string,age:number):string{

//     return `${name} --- ${age}`;
// }
   
// alert(getInfo('zhangsan',40));



//没有返回值的方法

    // function run():void{

    //     console.log('run')
    // }
    // run();



// 3.2、方法可选参数

    // es5里面方法的实参和行参可以不一样,但是ts中必须一样,如果不一样就需要配置可选参数 



   /*
    function getInfo(name:string,age?:number):string{

            if(age){

                return `${name} --- ${age}`;
            }else{

                return `${name} ---年龄保密`;
            }


    }

    alert(getInfo('zhangsan'))

    alert(getInfo('zhangsan',123))
   */



//注意:可选参数必须配置到参数的最后面

//错误写法
  /*
   function getInfo(name?:string,age:number):string{

            if(age){

                return `${name} --- ${age}`;
            }else{

                return `${name} ---年龄保密`;
            }
           

    }

    alert(getInfo('zhangsan'))
  */

// 3.3、默认参数 可选参数

    // es5里面没法设置默认参数,es6和ts中都可以设置默认参数

    /*

            function getInfo(name:string,age:number=20):string{

                        if(age){

                            return `${name} --- ${age}`;
                        }else{

                            return `${name} ---年龄保密`;
                        }
                    

            }

            // alert( getInfo('张三'));
            alert( getInfo('张三',30));
    */



// 3.4、剩余参数

        // function sum(a:number,b:number,c:number,d:number):number{

        //     return a+b+c+d;

        // }


        // alert(sum(1,2,3,4)) ;


//三点运算符 接受新参传过来的值


    /*
        function sum(...result:number[]):number{

            
            var sum=0;

            for(var i=0;i<result.length;i++){

                sum+=result[i];  
            }

            return sum;

        }

        alert(sum(1,2,3,4,5,6)) ;
    */




/*

    function sum(a:number,b:number,...result:number[]):number{

                
            var sum=a+b;

            for(var i=0;i<result.length;i++){

                sum+=result[i];  
            }

            return sum;

        }

        alert(sum(1,2,3,4,5,6)) ;
*/
                

// 3.5、ts函数重载

// java中方法的重载:重载指的是两个或者两个以上同名函数,但它们的参数不一样,这时会出现函数重载的情况。

// typescript中的重载:通过为同一个函数提供多个函数类型定义来试下多种功能的目的。

//ts为了兼容es5 以及 es6 重载的写法和java中有区别。



//es5中出现同名方法,下面的会替换上面的方法 
    /*
        function css(config){

        }

        function css(config,value){


        }
    */



//ts中的重载

            // function getInfo(name:string):string;

            // function getInfo(age:number):string;

            // function getInfo(str:any):any{

            //     if(typeof str==='string'){

            //         return '我叫:'+str;
            //     }else{

            //         return '我的年龄是'+str;
            //     }

            // }

            // alert(getInfo('张三'));   //正确


            // alert(getInfo(20));   //正确


            // alert(getInfo(true));    //错误写法



            function getInfo(name:string):string;
            function getInfo(name:string,age:number):string;
            function getInfo(name:any,age?:any):any{
                if(age){

                    return '我叫:'+name+'我的年龄是'+age;
                }else{

                    return '我叫:'+name;
                }
            }

            // alert(getInfo('zhangsan'));  /*正确*/

            // alert(getInfo(123));  错误

            // alert(getInfo('zhangsan',20));



// 3.6、箭头函数 es6

//this指向的问题 箭头函数里面的this指向上下文

    // setTimeout(function(){

    //     alert('run')
    // },1000)

    setTimeout(()=>{

        alert('run')
    },1000)


相关文章
|
8月前
|
JavaScript 前端开发 编译器
TypeScript 函数第一章
TypeScript 函数第一章
84 4
|
8月前
|
JavaScript 前端开发 测试技术
[小笔记]TypeScript/JavaScript模拟Python中的Range函数
[小笔记]TypeScript/JavaScript模拟Python中的Range函数
80 0
|
8月前
|
JavaScript 编译器
TypeScript中泛型在函数和类中的应用
【4月更文挑战第23天】TypeScript的泛型在函数和类中提供了灵活性,允许处理多种数据类型。了解泛型是掌握TypeScript类型系统的关键。
|
4月前
|
JavaScript
typeScript基础(3)_ts函数默认值和可选参数
本文介绍了在TypeScript中如何使用函数的默认值和可选参数。展示了如何为函数参数指定默认值,使得在调用函数时可以省略某些参数,以及如何定义可选参数。
267 2
|
3月前
|
移动开发 JavaScript 前端开发
TypeScript:数组类型&函数使用&内置对象
本文介绍了 TypeScript 中的数组类型、对象数组、二维数组、函数、函数重载、内置对象等概念,并通过代码示例详细展示了它们的使用方法。还提供了一个使用 HTML5 Canvas 实现的下雨效果的小案例。
|
4月前
|
JavaScript
typeScript基础(7)_函数的类型
本文介绍了TypeScript中函数的类型,包括函数声明与函数表达式的类型注解,如何定义函数的参数类型、返回类型,以及可选参数和参数默认值。还探讨了函数的剩余参数、如何使用接口定义函数的形状,以及函数重载的概念和实践。
40 0
|
6月前
|
JavaScript 前端开发 程序员
Typescript 【实用教程】(2024最新版)含类型声明,类型断言,函数,接口,泛型等
Typescript 【实用教程】(2024最新版)含类型声明,类型断言,函数,接口,泛型等
97 0
|
6月前
|
JavaScript
TypeScript(六)函数
TypeScript(六)函数
41 0
|
7月前
|
JavaScript 前端开发 API
TypeScript 函数
TypeScript 函数
|
7月前
|
JavaScript 前端开发
typescript 函数类型
typescript 函数类型