博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js不好学并不是因为它难,而是因为它容易混淆
阅读量:5908 次
发布时间:2019-06-19

本文共 1255 字,大约阅读时间需要 4 分钟。

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

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

转载地址:http://blvpx.baihongyu.com/

你可能感兴趣的文章
-msoft-float -mhard-float区别
查看>>
STL之string篇
查看>>
canvas里设置width和css里设置width和js里设置width的区别
查看>>
解析spring启动加载dubbo过程
查看>>
uva 1400 - "Ray, Pass me the dishes!"
查看>>
MAVEN 配置阿里巴巴镜像
查看>>
今天我来了
查看>>
Java并发编程(一)
查看>>
Android 运行过程
查看>>
结队项目——智能订餐系统用户调研报告
查看>>
php中 $$str 中 "$$" 的解释
查看>>
程序猿的能力拓展模型
查看>>
[LeetCode][Java] Container With Most Water
查看>>
线程专用钩子和全局钩子的差别
查看>>
Swift开发教程--怎样自己定义TabBarItem的图片显示
查看>>
【Bug历练手册】Frame must be terminated with a null octet
查看>>
MySQL5.6 windows7下安装及基本操作
查看>>
cin.get()、流和缓冲区
查看>>
设计模式及面向对象的设计原则
查看>>
通讯录封装实现
查看>>