当前位置: 首页 > article >正文

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,参数为空

http://www.kler.cn/a/5777.html

相关文章:

  • Unity中 Xlua使用整理(二)
  • Flink三种集群部署模型
  • 基于Springboot+Vue的仓库管理系统
  • 人工智能-数据分析及特征提取思路
  • STM32F4分别驱动SN65HVD230和TJA1050进行CAN通信
  • 详解Sonar与Jenkins 的集成使用!
  • GPT-4报告解读
  • 【HDR图像处理】HDR图像,HDRI技术的一些基础概念 | GPT对话记录
  • Appium - 自动化测试框架 - 工作原理、环境搭建
  • SpringBoot整合SpringSecurity权限控制(动态拦截url+单点登录)
  • 多机器人集群网络通信协议分析
  • 设计模式-结构型模式-适配器模式
  • Python字符串常用方法
  • 初赛-图的概念
  • PyTorch动态图 vs. TensorFlow静态图:深度学习框架之争
  • 网站是怎么屏蔽脏话的呢:简单学会SpringBoot项目敏感词、违规词过滤方案
  • 信创办公–基于WPS的PPT最佳实践系列 (将幻灯片组织成节的形式)
  • 【语音唤醒】TC-ResNet:移动设备上实时关键词检测的时间卷积算法
  • RK3568 JDK RXTX-JAVA串口485开发
  • python 基础知识复习之元祖
  • 小驰私房菜_05_camx 添加水印信息
  • 如何使用LaTeX中的命令【ChatGPT 3.5 vs. ChatGPT 4】
  • chatGPT身份指令
  • 开启元宇宙新时代,VR全景,体验虚拟展厅
  • 遗传算法 |运筹优化
  • 2023-3-30刷题情况