JS基础 -- 返回值的类型与函数嵌套的使用和调用

        /*
         * 返回值可以是任何的数据类型,包括对象、函数
         *  
         */
        //返回值是对象
        function fun2() {
            //对象数据类型
            var obj = {
                name: '神王'
            };
            return obj;

        }
        var a = fun2();

        console.log("a = " + a);
        /*
         * 返回值是函数
         * 函数是可以无限嵌套的,
         */
        function fun3() {
            //再声明一个函数
            function fun4() {
                function fun5() {
                    console.log('啊哈哈');
                }

                //                  return '啊哈哈';
                return fun5;
            }
            /*
             * 如果fun4函数中是有return的,那么在调用时必须是fun4(),带小括号
             * 如果fun4函数中没有return,那么在调用时必须是fun4,不带小括号
             */
            return fun4;
        }
        //可以使用变量调用
        var b = fun3();

        //          console.log(b);

/*
         * 也可以使用下面调用方法
         * 使用这个方式调用fun4函数时,那么fun4函数中就不能使用return,不需要返回值
         * 如果函数中嵌套几个函数在这里调用时后面就要加几个小括号,并且在函数调用内部函数时,需要使用return 函数。
         * 但是,最内层函数中也就是嵌套的最后一个函数内不需要return
         * 语法:
         * function fun1() {
         *    function fun2() {
         *        function fun3() {
         *          //这一层函数不需要return 返回值
         *        }
         *        return fun3;
         *    }
         *    return fun2;
         * }
         * 
         * 调用时:
         * fun1()()();
         * 
         * 调用时,除了第一个小括号,其他的小括号分别代表一个函数,也就是说函数-1中嵌套了一个函数-2,
         * 那调用时函数-1()后面紧跟着一个小括号,这个小括号就是函数-2
         */

        fun3()()();

      /*
         * 当函数中有两个平级的函数时,需要在调用函数后面第一个小括号中传值,根据特定的值来判断需要执行那个函数
         * 而,第二个小括号中也可以传值,但,不会起到决定需要调用两个平级函数的其中一个,正常传值就可以了。
         * 需要注意的是,在不写if判断时,两个平级的函数或者多个平级函数同时存在不会报错,但是,只能出现一
         * 个return,如果一个函数下面跟一个return会报错,如下列错误例子:
         * 错误例子:
         * function fun1() {
         *    function fun2() {
         *          //这一层函数不需要return 返回值
         *    }
         *    return fun2;
         * 
         *    function fun3() {
         *          //这一层函数不需要return 返回值
         *    }
         *    return fun3;
         * }
         * 调用函数:
         * fun1()();
         * 
         * 这样的写法是错误的,一个函数中只能出现一个return,不可以出现多个return。
         * 如果是必须出现多个平级函数,那么就需要if判断和switch语句开隔开使用,根据if判断条件和switch语句条件,
         * 来决定应该执行多个平级函数中的某一个函数
         * 
         * 下面的下面是正确的。
         */

        function abc(a) {

            if(a == 'abc2') {
                console.log("-=-=-=-=-" + a);

                function abc2() {
                    console.log("我是abc2()")
                };
                return abc2;
            } else {
                console.log("----------" + a);

                function abc3() {
                    console.log("我是abc3()")
                };
                return abc3;
            }

        };
        //调用函数时,需要传值
        abc('abc2')();

/*
* 这种写法的前提条件是制定规则,指定一个值,来区分多个平级函数,就相当于是人,
* 每一个人相同且平级,而为了有效的识别每一个人,所以出现了身份证号的存在。
* 这个指定的值就相当于给每一个函数设置一个身份证号,通过调用最外层的函数传来的
* 值,去判断这个值是属于哪个函数的值。
*/

有写的不对的请在评论区留言,我会尽快更改,谢谢大家!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,692评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,482评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,995评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,223评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,245评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,208评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,091评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,929评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,346评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,570评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,739评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,437评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,037评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,677评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,833评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,760评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,647评论 2 354

推荐阅读更多精彩内容

  • 看 海 我是带着伤痛来看大海的, 岁月流转大海一直在那里等我。 我扑进大海,海水轻抚着我的伤痕, 一点点地敷药,扎...
    邰枫的台阅读 576评论 0 7
  • 今天是春节前的最后一个星期,也是最后一天上班。从2/1开始就每天加班,直到昨天,没有再安排加班。今天也没有。确认了...
    木子馠阅读 189评论 0 0
  • 人生如戏,没有彩排,每天上演的都是现场直播。没有走心的努力,再好的演技也演不活人生这场大戏。我们痛恨这个功利的世界...
    shalen阅读 517评论 3 7
  • 相信很多人都有和我类似的困惑: 为什么我读了一些书,读的时候很受益,但几个月后发现自己还是没有大的成长和改变? 为...
    露慢慢阅读 233评论 0 3