js基础04

1.函数:命名规则:和变量命名规则类似;
1.1 由数字,字母,下划线,$符号组成,不能以数字开头;
1.2 不能是关键字和保留字
1.3 区分大小写
函数的命名规范:函数名字必须有意义;遵守驼峰命名法;
2.函数的覆盖问题:
函数的声明和函数的表达式的区别:函数的声明是具名函数:声明的格式:

function fn(){}

函数表达式是匿名函数,没有名字,依靠一个变量来接收,

var fn = function(){}

如果两个函数都是函数的声明,且函数名相同,那么后面的函数会覆盖前边的函数;

function fn(){
  console.log('函数声明')
  }
  function fn(){
   console.log('我是第二个fn')
   }
   fn()   //我是第二个fn
function fn(){
  console.log('函数声明')
  }
  fn() //我是第二个fn
  function fn(){
   console.log('我是第二个fn')
   }
   fn()   //我是第二个fn

第二个代码是由于函数的提升,使得第一个fn()调用的时候,仍然输出的是后面定义的函数;
这个语句真正的执行顺序其实是这样的:

function fn(){
  console.log('函数声明')
  }
   function fn(){
   console.log('我是第二个fn')
   }
  fn() //我是第二个fn
 
   fn()   //我是第二个fn

第二个定义的函数由于和第一个定义的函数的名字是一样的,所以第一个被第二个覆盖了。

如果两个函数都是表达式,且函数名相同,函数的调用会调用最近的一个;

var fn = function(){
  console.log('我是第一个函数表达式fn')
 }
 fn()  //我是第一个函数表达式fn
var fn1 = function(){
  console.log('我是第二个函数表达式fn1')
}
fn1()  //我是第二个函数表达式fn1

3.函数的内置对象
arguments 是当前函数的内置属性,返回的是一个伪数组,其长度由我们传递的实参决定,遍历出来的元素,是我们传递的参数;
其主要作用是让我们知道我们传递了多少个参数,参数的数值是什么;
4.匿名函数
匿名函数是没有名字的函数:
匿名函数不能直接调用,需要通过匿名函数的自调用的方式来执行;

(funcion(){
alert(123)
}

5.函数也是一种复杂的数据类型。可以把函数作为参数引入

function fnNum(x){
    conlose.log(x);
    x();
 }
 fnNum(function(){conlose.log('函数作为参数传入;')})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值