1.定义函数
函数写法:
方法一:
function abs(x){
//此处为函数内容
return ;
}
方法二:
var abs=function(x){
//此处为函数内容
return ;
}
注:
- 方法一和方法二相同;
- 如果没有执行rerurn,函数执行完也会返回结果,结果是undefined。
参数问题:
- javascript可以传任意参数,也可以传不传参数(即使多了也不会报错)
- 参数(多余参数或不符合要求参数)进来是否存在问题?
- 假设不存在参数,如何规避?
2.arguments
arguments是js免费赠送的关键字,代表传递进来的所有参数,是一个数组
下面函数为遍历传入值的函数
function abs(x){
console.log("x=>"+x);
for(let i = 0 ; i < arguments.length ; i++){
console.log(arruments[i]);
}
}
3.rest
ES 6 引入的新特性,获得除了已定义的参数外的参数
以前:(ES 6 以前)
if(aruguments.length > 2){
for(let i = 2; i < arguments.length ; i++){
//....
}
}
现在:(调用rest)
function abs(a,b,...rest){
console.log("a=>"+a);
console.log("b=>"+b);
console.log(rest);
rest参数只能写在最后面,必须用…标识
4.函数的作用域
在javascript中,var定义的变量是由作用域的
1.函数体中声明,函数外无法调用;
2.内部函数可以访问外部函数的成员,反之则不行;
3.内部函数变量和外部函数变量重名,从内部函数优先调用内部函数。
提升变量作用域
js中在后面定义的变量也相当于在前面定义,在后面使用。
因此所有变量都尽量在前面定义,后面使用(便于维护)
4.全局对象window
var x='aaa'
alert(x);
alert(window.x); //默认所有变量都自动绑定在window对象下
javascript 实际上只有一个全局作用域,任何变量(函数也可以视为变量),假设在没有函数作用范围内找到,就会向外查找,如果在全局作用域都没有找到,报错 : RefrenceError
规范
由于所有的全局变量都会绑定到window上,如果不同的js文件,使用了相同的全局变量,冲突!!如何能够减少冲突?
//唯一全局变量
var xApp = {};
//定义全局变量
xApp.name = 'xiaoli';
xAPP.add function ( a , b ){
//。。。。
}
把自己的代码全部放入自己定义的唯一空间名字中,来减少冲突。
ES 6 中let可以定义局部变量
ES 6之前,定义常量的方法:只要用大写字母命名的就是常量,建议不要修改
ES 6后使用const 定义常量
const x=5;
x=2; //此处会报错(常量不能修改)