修炼js 2函数及作用域

22 篇文章 0 订阅

Js函数

函数对于程序员来说都不陌生,在此记录一下我对Js函数的认识。

1、声明函数语法如下:

//方式一
function fun1(){
	console.log("函数1");
}

//方式二 函数表达式
var fun2 = function(){
	console.log("函数2");
}

//方式三 函数表达式
var fun3 = ()=>{
	console.log("函数3")
}

//方式四
var fun = new Function(console.log("函数4"))

看到这里我们已经会定义函数了,但是我们还经常看到类似如下写法的函数

2、立即执行函数


    (function () {
        console.log("你好我是一个函数")
    })()
    
    var a = function () {
        console.log("你好我是另外一个函数")
    }()

以上两种方式都是立即执行函数,如果是函数表达式则直接在函数体后面写一对小括号,反之需要用小括号先包裹函数再跟一对小括号。那么为什么不是函数表达式要多加一个括号呢,我的理解是:多的这个括号目的是把目标函数转换为函数表达式。可能不是前端的盆友也听过 闭包函数。

3、闭包

	
    function fun(){
        this.name = '狗蛋';
        this.age= 20;
		// 闭包函数
        var func=function(){
            console.log(this.age);
        }
        return func;
    }
    fun()()

我的理解是某个函数的内部函数还持有该函数的内部变量,在该函数的外部被执行了这就是闭包。闭包会导致变量无法被Js的垃圾回收机制回收,过多使用会导致性能下降。

4、this指向

对于接触前端不久的同学来说this指向无疑是一大难点,这里我记录一下针对函数的this指向,接下来先看两个例子。

	// 例子一
	name = "test"
    var obj1 = {
        name : "zyx",
        getName:function (){
            return this.name
        }
    }
    console.log(obj1.getName());


	//例子二
    name = "test"
    var obj1 = {
        name : "zyx",
        getName:()=>{
            return this.name
        }
    }
    console.log(obj1.getName());

如果把这个代码复制到控制台中执行一下的话,你会发现这两个看上去差不多的代码输出了两个不同的结果。那么是什么原因导致的呢,在这里我通俗的解释一下。首先是非箭头函数 (()=>:即箭头函数)的函数的this会绑定在代码运行期间,谁调用了这个函数那么这个函数的this就指向谁,那么箭头函数呢?箭头函数的this会指向所在作用域的父级作用域,也就是说例子二的this其实就是window,正常情况下是这样的。接下来我们再看两个特殊一点的例子。

  	// 例子一
    name = "test"
    var obj1 = {
        name : "zyx",
        getName(){
            return this.name
        }
    }
    var obj2 = {
        name : "zs"
    }

    console.log(obj1.getName.call(obj2));  


	// 例子二
    name = "test"
    var obj1 = {
        name : "zyx",
        getName:()=>{
            return this.name
        }
    }
    var obj2 = {
        name : "zs"
    }

    console.log(obj1.getName.call(obj2));    

这两个例子比起上边两个稍微复杂了一点,call是Js的预设函数 它的其中一个作用是改变this的指向,就是将 getName 函数的 this 显式的与 obj2 绑定,所以例子一的结果不难的出为 zs,这个例子二与上面的例子二输出一致,还是由于箭头函数导致的,可以把代码复制到控制台亲自试一试,实践是检验真理的唯一标准,虽然我说的不是真理😂😂看到这里函数基本上就差不多了,接下来看作用域

5、作用域

在es5及之前有全局作用域、函数作用域,es6新增了块级作用域,tips:(学习作用域之前请先去看Js变量这样有助于学习)。那么块级别作用域有什么好处吗。
1、外部作用域无法访问块级作用域内的变量
2、内部作用域可以定义与外部的同名变量而不受影响
3、立即执行函数 IIFE变得不在必要

当然,如果说我描述错了或者是有偏差,可以私信我,我们探讨交流一下。最后当然也是干货啦。函数经典面试。 

我遇到的面试官问的问题
1、写一个函数深拷贝
2、能写一个函数实现找出数组中重复次数最多的字符吗
3、实现给两个对象找出对象中相同key并取出value tips:时间有点久了忘记是不是这么描述的了

好了,今天就聊到这儿吧!如果你觉得还不错别忘了点个赞,转发一下,让更多的人看到,一起学习,一起进步,一起成长为一个优秀的前端工作者!!蟹蟹啦。

结语:函数非常强大总觉得自己写的不到位,可能是我的知识贮备还没到那个地步,之后的每周我都会在csdn更新一
篇关于Js的博客,当然包括nodejs的部分知识。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值