js不好学并不是因为它难,而是因为它容易混淆

这段时间我主讲的前端零基础课,让我感觉js这东西是越来越简单了。你当然可以说我这是越讲课越熟。确实是有这部分因素,但更主要的是,我发现js中虽然有许多的概念各不相同,但在具体的代码实现中,基本都是非常类似,甚至是完全一样的。这就导致前端新人在学习的过程中,学着学着,就分不清谁是谁了。

例如在27号的课程中,主要讲js的自定义对象。在课程中提到了,函数,方法,对象,又加个构造器,,这就已经四个概念了,但使用代码表现出来,

function abc(){

console.log('abc')

}

全都是一样的,就是一个名为abc的function,你单独的写一个,

function abc(){

console.log('abc')

}

这就是个孤立的函数。

//-------------

function abc(n){

console.log(n)

}

这时,你可以称,它是个接收参数并输出的方法。

//-------------

但同时,函数还是个对象!因为要把它赋值给变量然后调用

Function

//-------------

function abc(){

console.log('abc')

}

new abc();

此时,这个abc函数又是个构造器

//-------------

那么它们什么时候是函数,什么时候是方法,什么时候是对象,又是什么时候是构造器?全看你想怎么去使用它们。

但对于新人来讲,有时就晕了,明明刚才还说是声明一个函数,怎么到这就变成构造器了?

再看什么私有方法,公共方法,全局变量,局部变量,

其实不过是写在函数外面或是里面的匿名函数和变量而已。说到底就是函数和变量。但却因为使用方式和环境的不同,搞出这么多名字。

这在我个人看来,还是因为js太过简单,但又要承载复杂的功能,只能是人为的用各种手段和名称去区分。

//-------------

js还有些明明很简单,我总觉得各种教程写的有些过于复杂了,也许是我理解的还不到位吧。

不说别的,就单说prototype和constructor,无非是函数里有个prototype属性,然后prototype里有个对象,这个对象里有个constructor,然后这个constructor的值是它所在的那个函数。。,就像这样:

简单吧,就是个一个套着一个的关系。但看网上的教程,什么引用,包含,指向,画的图也左一道又一道的,看不懂。

//-------------

再来说闭包,啥叫闭包?

图上画的很清楚,那个返回的子函数及其作用域,就是闭包。

但看看网上关于闭包的资料,很多写的,,反正我开始时在学js的时候,看闭包是很久也理解不了。

//-------------

就不多说了,js当然也不简单,依然是很复杂的东西,需要大量的代码练习才能掌握。但既然我已经懂了,明白了。那么在我这里,就是怎么简单怎么讲,能一句话说明白就不用二句话。

在我看来,有时间多讲讲代码实现,比我费挺大劲给你讲明白一个概念,要重要的多。

猜你喜欢

转载自blog.csdn.net/qq_40943219/article/details/86557458