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


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




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值