JavaScript函数及面向对象

JavaScript函数及面向对象

4.1、函数定义及变量作用域

定义方式一

绝对值函数

function abs(x){
    
    
  if(x>=0){
    
    
    return x;
  }else{
    
    
    return -x;
  }
}

一旦执行到return代表函数结束,返回结果!

如果没有执行return,函数执行完也会返回结果,结果就是undefined

定义方式二

var abs = function(x){
    
    
  if(x>=0){
    
    
    return x;
  }else{
    
    
    return -x;
  }
}

function(x){…} 这是一个匿名函数,但是可以把结果赋值给abs,通过abs就可以调用函数

方式一和方式二等价!

调用函数

abs(10)  //10
abs(-10) //10

参数问题:JavaScript可以传任意个参数,也可以不传递参数~

参数进来是否存在的问题?

假设不存在参数,如何规避

function abs(x){
    
    
    //手动抛出异常
    if(typeof x!=='number'){
    
    
        throw 'Not a number';
    }
    if(x>=0){
    
    
        return x;
    }else{
    
    
        return -x;
    }
}

arguments

arguments是一个JS免费赠送的关键字

代表:传递进来的所有参数,是一个数组

var abs=function(x){
    
    
    //手动抛出异常
    console.log("x=>"+x);
    for (var i = 0; i < arguments.length; i++) {
    
    
        console.log(arguments[i]);
    }
    if(typeof x!=='number'){
    
    
        throw 'Not a number';
    }
    if(x>=0){
    
    
        return x;
    }else{
    
    
        return -x;
    }
}

问题:arguments包含所有的参数,我们有时候想使用多余的参数来进行附加操作。需要排除已有的参数~

rest

以前:

if(arguments.length>2){
    
    
    for (let i = 2; i < arguments.length; i++) {
    
    
        //.....
    }
}

ES6引入的新特性,获取除了已经定义的参数之外的所有参数~ …

<script>
    function aaa(a,b,...rest){
    
    
        console.log("a=>"+a);
        console.log("b=>"+b);
        console.log(rest)
    }

rest参数只能写在最后面,必须用…标识。

4.2、变量的作用域

在JavaScript中,var定义变量实际是有作用域的。

假设是在函数体中声明,则在函数体外不可以使用~ (闭包)

function qj(){
    
    
    var x=1;
    x=x+1;
}
x=x+2;  //Uncaught ReferenceError: x is not defined

如果两个函数使用了相同的变量名,只要在函数内部,就不冲突

内部函数可以访问外部函数的成员,反之则不行。

养成规范:所有的变量定义都放在函数的头部,不要乱放,便于代码维护;

全局函数

//全局变量
function f(){
    
    
  console.log(x);
}
f();
console.log(x);

全局对象window

var x='xxx';
alert(x);
alert(window.x); //默认所有的全局变量,都会自动绑定在window对象下;

alert()这个函数本身也是一个window变量

4.3、方法

定义方法

方法就是把函数放在对象的里面,对象只有两个东西:属性和方法

var kuangshen={
    
    
    name:'秦疆',
    birth:2020,
    //方法
    age:function(){
    
    
        //今年 - 出生的年
        var now = new Date().getFullYear();
        return now - this.birth;
    }
}
//属性
kuangshen.name
//方法,一定要带()
kuangshen.age()

this.代表什么?才开代码来看看

 function getAge(){
    
    
          //今年 - 出生的年
          var now = new Date().getFullYear();
          return now - this.birth;
  }
var kuangshen={
    
    
    name:'秦疆',
    birth:2020,
    //方法
    age:getAge
}

this是无法指向的,是默认指向调用它的那个对象;

apply

在js中可以控制this指向

 function getAge(){
    
    
          //今年 - 出生的年
          var now = new Date().getFullYear();
          return now - this.birth;
  }
var kuangshen={
    
    
    name:'秦疆',
    birth:2020,
    //方法
    age:getAge
}

getAge.apply(kuangshen,[]);//this,指向kuangshen,参数为空

猜你喜欢

转载自blog.csdn.net/m0_59090147/article/details/129850966