Javascipt(3)

JS中的函数

一、定义绝对值函数

第一种方式:

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

第二种方式:

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

函数相当于是匿名的,可以把结果赋值给abs,通过abs就可以调用函数。 也就是当省略函数名的时候,该函数就成为了匿名函数。

二、函数参数

可以传任意个参数,也可以不传参数。

  • Q:进来的参数如果存在问题,怎么去解决?
    假设参数不存在,如何去规避?
var abs = function(x) {
    //手动抛出异常来判断
    if(typeof x!== 'number') {
        throw 'Not a Number';
    }
    if(x>=0) {
        return x;
    } else {
        return -x;
    }
}

三、argument对象(关键字)

能获取传递进来的所有的参数,是一个数组

arguments[0]
arguments[1]
arguments[2]

当然,参数也可以被赋值:

arguments[1] = 'new value';

例如:

var abs = function(x) {
    console.log("x=>"+x);
    for(var i=0;i<arguments.length;i++) {
        console.log(arguments[i]);
    }
    if(x>=0) {
        return x;
    } else {
        return -x;
    }
}

四、rest

获取除了已定义的参数外所有的参数

Rest 参数可以通过使用三个点...并在后面跟着包含剩余参数的数组名称,来将它们包含在函数定义中。这些点的字面意思是将剩余参数收集到一个数组中

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

Rest 参数必须放到参数列表的末尾

五、变量

1、变量的作用域

①函数体内声明的变量,不能在函数体外使用。(可以用闭包实现)
②如果两个函数使用了相同的变量名,只要在函数的内部,不会冲突。
③内部函数可以访问外部函数的,外部函数是不可以访问内部函数的。
eg.

function f() {
    var x = 1;
    function f3() {
        var y = x+1;//2
    }
        var z = y+1;//Uncaught ReferenceError: y is not defined
    }

④内部函数和外部函数变量重名了是不会互相影响的。
PS :① js里面没有函数重载的概念,在js中,定义了两个同名函数后,后面的函数会覆盖前面定义的函数。
②而JS中函数变量查找是由“内”向“外”查找,假设外部存在同名的函数变量,则内部函数会自动屏蔽外部函数。

另外,注意规范性→所有的变量定义都放在函数的头部

2、全局变量
  • 对象为windows
var x = "xxx";
window.alert(window.x);

JS只有一个全局作用域。
但因为,万物皆对象,所以,如果在不同的js文件重用了相同的全局变量,就会有冲突,这个时候应该把代码放进定义的唯一的空间名字中,以降低全局变量命名冲突的问题。

  • 规范:
//唯一全局变量
var hong={  }
//定义全局变量
hong name="yangd"
hong.add=function(a,b){
        return a+b;
}
  • jQuery库把所定义的都放到jQuery中,用简化符$(selctor).action()
3、在全局作用域下用let、const(常量)定义的变量
  • let用来定义局部作用域的变量
    let 声明的变量只在 let 命令所在的代码块内有效,使用 var 关键字重新声明变量可能会带来问题。
var i = 5;
for (var i = 0; i < 10; i++) {
    
}
// 这里输出 i 为 10
var i = 5;
for (var i = 0; i < 10; i++) {
    // 一些代码...
}
// 这里输出 i 为 10

在第一个实例中,使用了 var 关键字,它声明的变量是全局的,包括循环体内与循环体外。
在第二个实例中,使用 let 关键字, 它声明的变量作用域只在循环体内,循环体外的变量不受影响。
但是,let不可以重复声明。

  • const
    const 声明一个只读的常量,一旦声明,常量的值就不能改变,也不能被重新声明。

4、方法

方法就是把函数放在对象里面,对象只有两个东西:一个方法,一个是属性。
即方法是存储为对象属性的函数。

var person = {
      name:"linyang",
      birth:2002,
      college:"Nan Da"//属性
    age:function() {
        var now = new Date().getFullYear();
        return now-this.birth; //方法
    }
}

创建了一个叫做person的对象,他有三个属性和一个方法(),而这里的方法,this.birth就是person.birth的值。
另外,调用方法,一定要加()

person.age()

this 属性

  • this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象
  • 情况1:如果一个函数中有this,但是它没有被上一级的对象所调用,那么this指向的就是window
    情况2:如果一个函数中有this,这个函数有被上一级的对象所调用,那么this指向的就是上一级的对象。
    情况3:如果一个函数中有this,这个函数中包含多个对象,尽管这个函数是被最外层的对象所调用,this指向的也只是它上一级的对象。
  • this永远指向的是最后调用它的对象,也就是看它执行的时候是调用的,即this他自己的方法被谁调用,它就是代表谁。
    还可以用apply自行改变this的指向
getAge.apply(person,[])

this指向了person,参数为空。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 规范1:所有的全局变量都会绑定在window上,不同的js文件,使用了相同的全局变量,就会产生冲突,如何避免?注:...
    玹鸾阅读 170评论 0 0
  • 1.数据类型 1.1概念篇 7种原始数据类型 引用类型 null是对象吗?为什么? 结论: null不是对象 解释...
    859z阅读 372评论 0 0
  • 一、理解 JavaScript 的作用域、作用域链和内部原理 作用域 javascript 拥有一套设计良好的规则...
    旭哥_阅读 357评论 0 1
  • 过了八月,马上到了金九银十的跳槽季,找工作的时候曾一周面试了十多家公司,从一开始被面试官虐的体无完肤到最后对答如流...
    视觉派Pie阅读 1,104评论 1 3
  • 一、对于MVVM的理解? MVVM 是 Model-View-ViewModel 的缩写。 Model代表数据模型...
    于冰馨阅读 156评论 0 0