JS基础--函数进阶

一、如果两个函数都是函数的声明,且函数名相同,那么后边的函数会覆盖前边的
复制代码
    function demo1() {
      console.log('我是demo1函数第一次声明')
    }
    demo1()   //我是demo1函数的第二次声明
    function demo1() {
      console.log('我是demo1函数的第二次声明')
    }
    // demo1()    //我是demo1函数的第二次声明
二、如果两个函数都是函数表达式,且函数名相同,函数的调用会调用最近的上边那一个
复制代码
    var demo2 = function () {
      console.log('我是demo2的第一个表达式')
    }
    demo2()  //我是demo2的第一个表达式
    var demo2 = function () {
      console.log('我是demo2的第二个表达式')
    }
    // demo2()   //我是demo2的第二个表达式
三、如果两个函数分别是函数表达式和函数声明,且函数名相同,函数表达式会覆盖函数声明
复制代码
    var demo3 = function () {
      console.log('我是函数表达式')
    }
    function demo3() {
      console.log('我是函数声明')
    }
    demo3() //我是函数表达式
四、函数的内置对象:任何一个函数都有一个内置对象arguments

作用:操作参数,参数是该对象数组的前几个元素

复制代码
    function fn1(x, y, z) {
      console.log(arguments)
      // console.log(x + y)
      console.log(arguments[0] + arguments[1])
      // length:实参的个数
      console.log(arguments.length) //2
      // callee.length:形参的个数
      console.log(arguments.callee.length) //3
    }
    fn1(10, 20)
五、匿名函数:没有名字的函数
复制代码
    (function () {
      console.log('我是匿名函数')
    })()
六、函数也是一种数据类型:引用类型

引用类型。通过typeof判断返回都应该是object

console.log(typeof fn1) //function

null -- null(object) function--object(function)

七、函数作为参数传入
复制代码
    function fn2(x) {
      /* 
        var x = 10
        var x = "web"
        var x = true
        var x = null
        var x = [1,2]
        var x = function(){console.log("我是函数也是参数");}
      */
      // console.log(x)
      x()
    }
    /*    fn2(10)
    fn2('web')
    fn2(true)
    fn2(null)
    fn2([1, 2]) */
    fn2(function () {
      console.log('我是函数也是参数')
    })
八、函数作为返回值返回
复制代码
    function fn3(x) {
      return x
    }
    var result = fn3(function(){console.log("我是函数也是返回值");})
    // console.log(result)
    result()
相关推荐
Percep_gan几秒前
解决java.security.InvalidKeyException: Illegal key size
java·开发语言
前端一课4 分钟前
【前端每天一题】🔥 第 9 题:防抖(debounce)与节流(throttle)的区别?如何实现?
前端·面试
前端一课5 分钟前
【前端每天一题】🔥 第 10 题:浅拷贝 vs 深拷贝?如何手写深拷贝?
前端·面试
前端一课10 分钟前
【前端每天一题】🔥 第 8 题:什么是事件委托?它的原理是什么?有哪些优点和常见坑? - 前端高频面试题
前端·面试
前端一课16 分钟前
【前端每天一题】🔥第7题 事件冒泡与事件捕获 - 前端高频面试题
前端·面试
前端一课17 分钟前
【前端每天一题】 第 5 题:Promise.then 执行顺序深入题(微任务队列机制)
前端·面试
前端一课21 分钟前
【前端每天一题】🔥 事件循环第 6 题:setTimeout(fn, 0) 执行时机详解
前端·面试
前端一课22 分钟前
【前端每天一题】🔥 第3题 事件循环 20 道经典面试题(附详细答案)
前端·面试
前端一课25 分钟前
【前端每天一题】第 2 题:var、let、const 的区别?(绝对高频)
前端·面试
前端一课28 分钟前
【前端每天一题】🔥第四题 原型与原型链 - 前端面试必考题
前端·面试