零基础前端入门,真正难在哪里?简说编程思想和逻辑思惟

不少同窗跟我说,学前端学的很迷茫,php

image

就这样,问他为啥迷茫吧,说也说不出来啥具体的。就是也学了一堆东西,也确实都是前端开发工做当中要用的。但依然不知道前路如何。css

这里就有一个“前端入门的标准”的问题。什么才是真正的前端入门?html

一、是你学了一堆的前端开发技术吗?前端

二、是你作了几个前端的大小不一的例子吗?vue

三、是你已经作了一二年的前端开发工做了吗?react

不要奇怪我把第三条也列上,确实有人已经工做了二三年了,但其实依然没有入门前端开发。程序员

我我的主观认为,判断一我的是否已经入门前端开发,有二个标准,编程

一、学了一堆的前端开发技术,如今的大大小小的培训机构基本都是这么作的;小程序

二、掌握并理解“编程思路与逻辑思惟”;app

我我的更喜欢第二个,就是掌握“编程思想与开发逻辑”的人。

什么叫编程思想呢?

很简单,其实就是提炼特征。例如,一筐苹果吧,把它的特征提炼出来,就这样,

苹果

_颜色:红

_形状:圆

_大小:200mm

_重量:100克

_品质:100%

_数量:100

那么,用JavaScript来表示,就是这样,

var _appleObj = {

color:'#f00',

shape:circular,

size:200,

weight:100,

quality:100%,

number:100

}

这个过程是什么呢?

对具体事物的抽象,在这个过程当中只提取出目标对象中咱们所须要的特征。而后在代码中表达出来。这里面的关键是,理解苹果的【颜色】和_appleObj中的【color】,它们两者之间的对应关系。

再,

例以下面这个京东的购物车,我随便添加了几个商品进去,就是下面的截图,

image

从哪开始入手作呢?不少新入门的同窗可能就没有思路了。若是用刚才抽象苹果的思路,就是这样,

购物车

_增长、减小商品按钮

_输入商品数量

_删除按钮

_单选按钮

_全选按钮

_结算按钮

_其它的相关调用、回调等

用JavaScript来表示就是这样,

var _cartObj = {

addFn : addfn,

minsFn : minsfn,

singleBtn : singlefn,

allselect : allselectfn,

payBtn : paybtn

}

而后再继续定义addfn、minsfn、singlefn、allselectfn、paybtn等函数,这就是从UI设计图中抽象出功能点,而后在编程范式里表达出来。这时,咱们已经拥有了一个购物车模块的JavaScript模型。

这种抽象的编程思想的思惟方式,是超越于任何编程语言之上的,它是对现实世界的提炼和抽象。不管你是用原生JavaScript,仍是vue,或react,都是这样,无非是写法不一样罢了。

我拥有这种思惟方式,因此我能够用一天学会php,写一个带登陆、注册的简单留言板出来,而后再在第2、三天,完全忘记php。不是显摆我有多么牛,而是说这种思惟方式是超越具体语言的。

若是不能理解这个实物和抽象之间的对应关系,那么不管你学习多少的css、html、js、jq、vue、h五、小程序...等,对你来说这些都是【死物】。由于你不知道该怎么用它解决问题与需求。说的有点啰嗦,但真心的但愿同窗们能明白它们的这个关系。

接下来再说说开发中的逻辑思惟。

逻辑思惟要严密且清晰,讲究的是环环相扣。它不一样于平常交流中的口头描述,“你今天上午去那帮我拿个东西。去哪?就你家那边一拐角”,这种基于生活经验的直观的描述就是混沌不清晰的。

一个经典的例子,口头描述,“让程序员,去买6个苹果回来,路上若是看见西瓜就买一个”。问,若是这个程序员在路上看到一个西瓜,他会买几个苹果回来?

答案是,一个苹果。为何呢?

由于,

if( 看见西瓜 ){

苹果 = 1

} else {

苹果 = 6

}

看到了吗?这就是使用平常生活思惟来写代码的结果。因此,编程开发中不能使用生活思惟方式,你必须环环相扣,造成一个逻辑链条。其中任何一环的不清晰,都会形成整个逻辑链条的崩溃。

编程由于须要抽象具体事物,因此它是以不一样的视角来看待现实世界。你看到一匹白马,说“好大好白的一匹马”,我看到的是,

var 白马 = {

腿:4,

颜色:#fff,

性别:公,

体重:200KG,

..

}

这算是另外一种形式的白马非马吗?

在实际工做中,PM会提出产品需求,确定是口语化的描述。说这个产品,有abcd等功能。而后前端开发等程序员再把它抽象出特色,设计出模型。

而后根据它的交互流程、前置后置的条件等,一步一步的实现。这个一步一步的实现,就是开发逻辑的链条,差了其中任何一环,都不能完成开发任务。

就例如你回家吃饭,若是用程序的逻辑思惟方式来思考,是这样的,

一、你回家;

二、家里要有米,若是没有,买米,若是买不到米,作不了饭;

三、家里要有电,若是没有,作不了饭;

四、家里要有水,若是没有,作不了饭;

这里面要把全部的条件、状况都考虑到。而不少状况其实在你写代码的时候并无发生。因此有人说,编程是给将来的人使用的。将来的人会怎么使用你开发出来的应用?你并不知道,因此你必须尽全力去无限穷尽全部可能。

编程思想是抽象特征,逻辑思惟是环环相扣,这二个东西合在一块儿,就是解决问题的方法和步骤。

而前端开发只不过是使用html、css、js,来实现编程思想和逻辑思惟所提供的解决问题的方法和步骤的一种工做而已。

因此,学习前端开发,实际上是学习如何用编程思想和逻辑思惟来解决问题,而不是学习html、css、js语言自己。

这也就是不少同窗,学完了,学会了html、css、js,却依然不知道怎么干活的根本缘由。因此说回本文的标题,《零基础前端入门,真正难在哪里?》就难在如何创建本身的编程思惟和开发逻辑。

由于篇幅所限,这篇文章写到这里基本也就要结束了。若是这方面还有什么其它的疑问,能够加我vx:blazeloulan,或在文章末尾留言给我。我感脚,我仍是能够给出一些建议的。

相关文章
相关标签/搜索