9.9笔记

函数:
 

  • 函数是一个可重用的代码块,用来完成某个特定功能。每当需要反复执行一段代码时,可以利用函数来避免重复书写相同代码。

  • 函数包含着的代码只能在函数被调用时才会执行,就可以避免页面载入时执行该脚本

  • 在JavaScript中,可以使用以下三种方法来定义一个函数

    • 使用function语句定义函数[最常用]

    • 使用Function()构造函数来定义函数

    • 在表达式中定义函数

1.Function构造函数定义函数:

var 函数名 = new Function(“参数1”,”参数2”,”参数3”……”函数体”);

2.function语句定义函数(最常用的方式)

function 函数名 (参数1,参数2……[形参]){
  <语句块>
  return 返回值
}

3.在表达式中直接定义函数:
 

var 函数名 = function (参数1,参数2,…){函数体};

调用函数:

1.直接调用

myFunction();或window.myFunction()

2.事件处理中调用

<div onclick="myFunction()"></div>

3.将函数的返回值赋给变量

var t = myFunction();

函数的参数:

形參:定义函数时,函数名后面()中的参数;JavaScript中的函数允许给行参赋初始值

实参:调用函数时,传递的参数

参数的匹配: 默认情况下,形參和实参是一一对应的 但是当传递的参数个数与函数定义好的参数个数可以不匹配当不匹配时

  • 如果传递的参数个数小于函数定义的参数个数,JavaScript会自动将多余的参数值设为undefined;

  • 如果传递的参数个数大于函数定义的参数个数,那么多余传递的参数将会被忽略掉。

function Test(a,b){
    alert(typeof(arguments)); // 获得类型
    alert(arguments[1]);      // 获取下标为1的参数值
    alert(arguments.length);  // 获取参数的长度
    alert(arguments.callee);  // 获取函数的所有内容
}
Test("zhang","li");

默认参数:

JavaScript中的函数允许给参数赋初始值

比如:我们在创建封装一个创建table表格的函数,如果任何参数不传,我们也想创建一个四行五列,并且背景颜色,各行换色的表格,这时候我们就可以使用表格来创建

案例:创建一个带默认参数的函数:

function tab(row,color='pink',color2='gray'){
  document.write('<table border="1" width="500">');
  for(var index = 0; index < row; index++){
    if(index%2 == 1){
      document.write('<tr bgcolor="'+color+'"><td>'+index +'</td><td>1</td><td>1</td><td>1</td><td>1</td></tr>');
    }else{
      document.write('<tr bgcolor="'+color2+'"><td>'+index +'</td><td>1</td><td>1</td><td>1</td><td>1</td></tr>');
    }
  }
  document.write('</table>');
}
tab(10,'gray','orange');

函数的返回值:
 

  • return语句并不是必须的

  • 默认情况下,函数的返回值为undefined

  • 在使用 return 语句时,函数会停止执行,并返回指定的值,return后面的代码不再执行

  • 什么情况下添加return?如果函数中的变量要在函数外进行调用;

变量的作用域:

全局变量: 在函数外声明的的变量为全局,在整个JS文档中生效

局部变量: 在函数内用var声明的变量为局部变量,只能在函数内部使用。

全局变量可以在局部的任意位置使用

局部变量不能在全局使用,如果想要在全局使用,可以去除前边的var或者将该值使用return返回到全局

预解析:

预解析,又称之为变量提升,在js代码真正执行之前,进行提前加载,把所有带有var和function的关键字进行预解析

  • JavaScipt代码是由浏览器中的JavaScript解析器来执行的

  • JavaScript解析器在运行JavaScript代码的时候分为两步:预解析和代码执行

  • 预解析分为变量预解析(变量提升)和函数预解析(函数提升)

  • 代码执行是按代码的书写顺序从上到下执行的

  1. 对于带有var和function关键字在预解释的时候操作

      var :只声明不定义

      function:既声明又定义 注:私有作用域下也要进行预解析

  2. 预解析只发生在当前的作用域下

就是当文档加载的时候,开始只对window进行预解析,函数执行的时候才会对里面的代码进行预解析

console.log(a); // 注意:预解析的问题,如果同时有变量和函数的预解析,那么函数的优先级高
var a = 'hello';
function a(){
  console.log(123);
}
// 优先执行栈内存中的内容
// function a(){
//     console.log(123);
// }
// var a = 'hello';
// console.log(a); // hello

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值