黑马程序员技术交流社区

标题: 前端基础班学习经历 [打印本页]

作者: 高震熊    时间: 2017-9-16 23:46
标题: 前端基础班学习经历
 学习的方法因人而异,但是,绝对离不开预习、认真听课和课后复习.
课堂上认真听讲这个很简单,就不说了,主要说说预习和复习.
预习,不仅仅是简单的看书,应该画一些重点字词、概念和一些重要的知识点;看完书以后,可以试着做做课后的练习题.这可以帮助你知道你是否基本了解了这些新知识.
至于复习,人长得越大,记忆力就越是递减.因此,常常复习很重要.但是,不必天天复习.你可以学的当天复习一次,然后隔一周,再隔两周,再一个月.如果一个月后你记住了这些新知识,那么,以后,只要你有空的时候再看看,就一定可以牢牢记住了.
关于做题.首先,应该备一本习题本,把平时的错题和经典例题抄在里头,那么,你只要看这习题本和一些基本的概念就可以了.
还有,做完以后,记得要总结解这一类题的方法,学会举一反三.这样做题,才有效.

1.善于想到就做,读文章或其他的时候,有不知道或不懂的字词,要马上就去查字典,然后把查到的东西标注在旁边
2. 上课认真听讲,要记好笔记,学会总结,不要老是记那些不重要的
3. 多看代码,然后总结他们写的好的原因,好在哪里?以后我要怎么学习他们.不要看了就完了
  中国的IT圈里有句话叫做“程序员吃的是青春饭”,许多IT公司也不愿意雇佣大龄程序员。因此,在有限的时间快速掌握高级技术变得非常重要。为了帮助新入行的小白快速走向技术人生的巅峰,这里分享一篇资深前端工作师总结的前端学习经验。
  这里主要讲的是自学,网站开发开发大致分为前端和后端,前端主要负责实现视觉和交互效果,以及与服务器通信,完成业务逻辑。其核心价值在于对用户体验的追求。

  前端的知识体系如上,可以按以下思路进行系统的学习:
  【基础知识】
  1. html + css 这部分可以在w3cschool 在线教程上学习(网址:www.w3cschool.cn),边学边练,每章后还有小测试。 之后可以模仿一些网站做些页面。在实践中积累了一些经验后,可以系统的读一两本书,推荐《head first html 与 css 中文版》,这本书讲得非常细,估计很多人都没有耐心细读,你可以根据自己的实际情况斟酌。
  2. java 要学的内容实在太多,如果没有其他编程语言的基础的话,学起来可能要费些力,还是建议先在 w3cschool上学习。之后建议马上看《java语言精粹》,js是一门很混乱的语言,这本书能够帮助你区分哪些是语言的精华,哪些是糟粕,对于语言精华,应该深入学习。糟粕部分能看懂别人写的代码就行,自己就不用尝试了。
  刚开始的时候,你往往会比较迷茫,因为你写的东西似乎看起来毫无用处,比如实现一个简单的计算器,读取一个文件等。这个时候你就应该去学着写一些让你觉得有意思的东西了,所以你应该学习更多的知识。
  【进阶】
  有了以上基础,就可以进行一般的静态网页设计,不过对于复杂的页面还需要进一步学习。
  1. css。必看《精通css》,看完这本书你应该对:盒子模型,流动,block,inline,层叠,样式优先级,等概念非常了解了。作为练习可以看下《css艺门之匠》这本书,它对标题,背景,圆角,导航条,table,表单等主题都有详细的介绍。
  2. java。上面提到内容还不足以让你胜任js编程。在有了基础之后,进一步学习内容包括:
  a) 框架。推荐jQuery,简单易用,在w3cschool简单学习js后,直接上手jQuery即可完成一些简单的项目。学习方法也很简单,照着产品文档做几个页面就行了,不用面面俱到,以后遇到问题查文档就行了。框架可以帮你屏蔽浏览器的差异性,让你能更专注与web开发学习的精髓部分。
  补充: 可以使用 codecademy 学习 java,jQuery,用户体验真的很好(感谢 TonyOuyang )。
  b) java 语言范式 。这个名字可能并不恰当,主是我找不到可以描述“面向对象”,“函数式”这个两个概念的概念。java不完全是一个面向对象的语言,它的很多设计理念都有函数编程语言的影子,甚至说如果你不用面向对象,完全可以把它理解成一门函数式编程语言。java的很多语言特性,都是因为他具有函数式语言的特点才存在的。这部分推荐先学习面向对象的基本理论,对封装,继承,多态等概念要理解,维基百科,百度百科会是你的帮手,另外推荐《object oriented java》,应该有中文版。对与函数式编程我了解的也不系统,不好多说,可以自己百度一下。
  c) java 语言内部机制。必须弄清如下概念:js中变量的作用域,变量传递方式,函数的定义环境与执行环境,闭包,函数的四种调用方式(一般函数,对象的方法,apply,call),以及四种调用方式下,‘this'指向的是谁。这部分内容你会在《java语言精粹》中详细了解。另外,你必须理解json。
  d) dom编程,这个web前端工程师的核心技能之一。必读《dom编程艺术》,另外《高性能java》这本书中关于dom编程的部分讲的也很好。
  e) ajax编程,这是另一核心技术。ajax建议在网上查些资料,了解这个概念的来龙去脉,百度百科,维基百科上的内容就足够了。真正编程是很容易的,如今几乎所有框架都对ajax有良好的封装,编程并不复杂。
  f) 了解浏览器差异性。这部分包括css和js两部分,浏览器差异内容很多,建议在实践中多多积累。另外对于浏览器的渲染模式,DOCTYPE等内容应该系统学习。
  【代码层面】
  有了以上知识,对于大多数小型网站,你应该已经可以写出能够工作的代码了。但要想成为更专业的前端,你还需继续努力。更高的要求大概还有四方面:1易维护,2可测试,3高性能,4低流量(移动端)。
  1. 易维护。对于页面你该理解‘样式’,‘数据’,‘行为’三者分离,对应的当然就是css,html,js。对于js代码,你最好了解设计模式,重构,MVC等内容。
  2. 可测性。
  3. 高性能。必读《高性能java》
  4. 低流量。移动端关注比较多。
  【工程层面】
  前端项目同样面临软件生命周期的各个环节,首先是代码管理,你必须熟练使用svn和git。其次是代码的构建,如今前端代码构建已经不是简单的压缩一下了,需要进行依赖管理、模块合并、各种编译,必须要学会使用grunt等前端构建工具,最近gulp比较火,也需要了解。
  补充:
  对于前端开发,基本内容就这些了,可以根据自己的兴趣爱好选择性学习以下内容。
  1. 交互设计。大公司依然有专业人士搞这些,不过不懂交互的前端一定不是好前端。推荐《简约至上》。
  2. 后端。应该说前段工程师必须至少了解一门后端语言,不过如果爱好也可深入学习,入手难度比较低的应该是php了。这部分由可分为基于页面,基于框架两种。大型项目都是基于框架开发的,建议至少了解一个MVC框架,比如php的ci, yii, yaf 等,好还框架的设计思想都大同小异。如今NodeJs在大公司已经得到普遍的使用,推荐大家使用在Node上使用Express框架做一些后端服务的开发。
  
  3. html5和css3 。HTML5规范已经于2014年10月28日发布了,移动端html5和css3已经得到了非常广泛的使用,相关的工具和环境也比过去好很多,有志前端必学。
作者: 白猫    时间: 2017-12-7 11:19
不错不错啊
作者: Haraella    时间: 2017-12-20 11:30
可以可以
作者: gzgd    时间: 2017-12-27 10:56
加油




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2