27函数

JavaScript 函数重中之重

  • 函数的五种声明方式
  • 如何调用函数
  • 什么是call stack
  • this 和 arguments
  • 作用域
  • 闭包
    function 函数名(参数,参数2){执行代码,return 结果} 就像一个过滤器,放进参数,输出结果.

如何声明一个函数?

  1. 具名函数
    function x(输入1,输入2){
    return undefined
    }
    注意: 变量可以是7种(null undefined boolean string number symbol object)类
    型,但是函数变量是变量的特例.
  • console.log() 括号里面只接受字符串,如果不是将会调用对象的toString方法
  • 因为函数永远有一个return返回值,所以即使是console.log()返回undefined因为console的源代码也是用一个函数来实现的,函数自带一个默认return undefined.
  • console只是打印一个对象,并不是返回一个对象.undefined是来自于他的源代码函数自带的默认返回值
  1. 匿名函数 var a = function (){} //这是第二种声明方法 var a = function b(){}//这是第三种声明方法
  • 具名函数function v(){ } 与 匿名函数 var a = function v(){} 的区别在于? 变态之的地方在于具名函数 console.log(v) 返回函数;匿名函数 报错. 同样的语法摆在不同的位置,意义不一样,这就是不一致,就是垃圾
  • 函数的第四种声明是window.Function a = new Function('x','y','return + x+y')

函数第五种声明就是箭头函数

  • sam = (x,y)=>{return x+y} 如果只有一个语句,可以去掉return和花括号,这是一起去掉的; 所以上面的函数等价于 sam= (x,y)=>x+y
  • 如果参数只有一个,(括号)也可以省掉sam=x=>x*x
  • 箭头函数是匿名函数,没有名字的
  • 如果花括号里面要放多个语句,那么就用分号

函数的name属性

  • 所有函数都有一个属性,如果是具名函数name就是名字;如果是匿名函数,name就是变量,如果两边都有的话:var f3 = function f4(){} ;f3的name是'f4'
  • 如果是用new产生的,那么他的name就是匿名(anonymous)

数据是可以直接用的,但是函数是要调用的

函数到底是什么?

  • 阮一峰说的 函数就是一堆代码的组合,说了等于没说.函数就是代码块,什么意思呢? 函数就是一段可以反复调用的代码块/函数还能接受输入不同的参数返回不同的值.

函数内存

  • 函数代码块里面的内容是被当成字符串存在内存里面.
  • 两种不同声明函数的方式,不同的内存方式:
  1. 具名函数: function f (x,y){return x+y} f 存一个地址,指向heap一块内存,这块内存存有2个东西.一个是params[x,y] 另外一个就是fbody{return x + y};这块内存又指向Function 函数对象,使用他的call方法
    用内存实现一个函数是怎样的呢?//eval 这是一个把字符串当成代码执行的函数

利用内存原理,写出函数的代码.

var f = {}
f.name = 'f'
f.params= ['x','y']//这个是假设的的属性
f.functionBody='console.log('xxxx')'
f.call = function(){return window.eval(f.functionBody)}
//这里穿插一个知识点,为什么要用函数包装Window......这些代码给f.call而不是直接用? 个人认为应该是用函数有利于扩展,日后更改代码可以直接在函数内增删改查代码,而直接赋值就没有这个功能,而且直接赋值直接给一个值,而不是一个函数地址,两者的内存不一样.
// 这样就清楚了f 与f.call的区别了,f只是一个函数,f.call是执行这个函数体

那么函数的本质我们就知道了:可以执行代码的对象就是函数

  • 那么f.call(硬核hardcore) 为什么不用f(糖sweet)? // 实际上f.call才是JavaScript真正的用法,f()是给小白用的,这对于领悟this有很大的意义
  • f.call()怎么用???

什么是this? f.call(undefined,1,2) undefined就是this;[1,2]就是arguments

// call的第一个参数可以用this得到,call后面的参数可以用arguments得到

  • 在普通模式下,f.call(undefined)这个undefined//也就是this,默认是Window
  • 也就是说f.call(第一个参数就是this)// JavaScript中的this 就是因为当年JavaScript研发的时候,老板要求开发的语言像java,这个历史原因造成的
  • arguments是一个伪数组: 伪数组就是具有数组键值对的形式,还有lengh,但是没有指向Array原型,也就是说一个对象的proto(甚至整个原型链)没有指向Array.prototype,所以它缺失了真正数组所具备的一些属性,比如push.
  • 一句话总结,call的第一个属性就是this,其他后面的就是arguments,因为历史原因本来一个argument搞定,但是强行搞了一个this来.

JavaScript函数调用,stack内存与heap内存的过程

  • 多层函数调用(穿越时空)就相当于有存档的走迷宫
  • 递归函数的调用,就像有存档的楼梯探险
  • 当stack内存被爆掉

JavaScript中的作用域就是树

-注意一句很错误的话:没有用var 声明的变量,a =3 声明的就是全局作用域的变量a,这是很错误的话. 首先a=3是一个赋值语句,他是赋值给a,但是当前作用域没有,就会沿着作用域链网上找,直到找到a赋值给他.如果没有a,也就是说整个作用域都没有,就会声明一个a并赋值给他,这时候才是叫 声明了一个全局作用域a,并赋值3给他.

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

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,114评论 0 13
  • Lua 5.1 参考手册 by Roberto Ierusalimschy, Luiz Henrique de F...
    苏黎九歌阅读 13,714评论 0 38
  • 1.函数参数的默认值 (1).基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。
    赵然228阅读 680评论 0 0
  • 芳龄二十好几, 踩在青春的尾巴上岌岌可危。 悲凉的回望过去, 尽是满目苍凉…… 添许矫情, 用文字祭奠已逝的青春。...
    凌泛涟漪阅读 236评论 0 2
  • 标题来自五月天的一首歌“有些人经过我身旁,在我心里钻洞……” 西瓜先生在我心里钻了个洞 看了篇爱情故事,然后想起了...
    alaeala阅读 430评论 0 0