关于学习javascript的一些建议
有被朋友或同事问到过,要如何学习前端技术,他们大多是已经掌握其他语言的程序员,或是计算机相关专业的在校生。
每次被问到,总要组织回忆一番,本着DRY原则,我还是根据我学习javascript(下文都简称JS)的经历,总结一些建议出来吧。
以后如果荣幸的被问起,直接发链接给他/她就可以了。
注: 以下内容仅根据本人的学习经验写成,绝非唯一方法, 仅供参考。 且由于本人水平有限,下面说的只是如何从不会JS,到简单入门原生JS,勉强算是领进门的一步。 至于更高级的话题, 请参考其他更专业的文章。
1. 前提
我认为,知识或技能,和财产不同,是无法赠予的。
要学习知识,或是掌握一门技能,第一个最大的前提,是你必须要动手去做。要学习前端或javascript技术,你必须要做好真正动手写javascript代码的准备。
简单来说就是,你需要主动的学习。
2. 对你学习有帮助的能力
下面这些能力并非必须,如果你还不会,那么以下这些能力可能会是你学习JS途中的附带收获:
1. 能使用搜索引擎来自行解决问题: 这是在网上自学的一个很重要的基础技能
2. 将任务拆分的能力: 如果能把一个看似巨大的难题,拆分成很多相对简单且自己能解决的问题,那么你的学习之路会顺畅很多,不容易因无法解决的难题而止步。
3. 设定并实现一个或多个目标
所谓目标,可能是在页面中输出“hello world”,或是你看到某个网站的某个效果很炫,那你就能把这个效果作为目标。 然后用尽你的聪明才智、刻苦耐劳, 把这个目标实现出来。
刚开始不建议把目标设得太难,这很可能打击你的积极性,让你继续不下去。
如果你发现原本设定的目标太难时,可以换一个稍微简单一点的目标。
实现目标过程中,你可能需要把目标拆分,变为若干个更容易解决的问题。
假设你找到的第一个目标,是在屏幕上输出hello world。
如果你是一个完全对javascript没有任何了解的人,可能你需要完成以下步骤:
1. 搜索一下,用什么软件可以写 JS?
你可能会搜到Dreamweaver、sublime text 2、 notepad、 chrome的控制台 等等。
2. 怎样能最简单的让JS运行并看到结果?
你可能需要编写一个html文件,并在里面添加script标签,并写下JS代码,然后在浏览器中打开这个html文件来观察结果。 这可能需要你顺便查找一些html的基础知识,你甚至可能会接触到css的概念。
或你会查到,可以直接在chrome的控制台(按F12,点击console选项卡)下,直接书写js代码,按回车后就能执行。且通过console.log(XX)就能把你的代码结果(XX)输出到控制台 中。
3. 查找JS关于变量声明、赋值的方法。 如果你是通过html输出, 还需要查找怎样用js在html中输出。
…………
第一个目标,如果不是很难,应该很快就能实现。 即使比较难, 通过拆分,和不懈的努力, 你也终究会实现的。
查找技术问题的话, 推荐到google或https://stackoverflow.com/, 百度、必应能解决的技术问题非常有限, 不过由于google常年被墙开始时只好先将就在百度、必应上碰运气了。
这一步的主要目的,是让你对JS有基本的认识, 对JS中的多个技术点建立起模糊的概念。接下来,你可以就已经了解到的“点”进行扩展学习,让这些点连接起来,形成你对JS更广阔的认知。
4. 开始系统的学习JS
如果你已经实现了自己定下的目标,你应该对JS和相关的知识已经至少有一些模糊的概念了。
你在实现目标过程中,已经碰到很多的JS概念(一般是些名词)。 也许是在写代码时自己发现的,也许是在搜索问题时顺带看见的。
你对它们好奇,但是还不太了解,甚至不知道怎么学习它们,或不知道怎么将它们和你已知的东西连起来。
这些概念可能包括对象、函数、闭包、原型链、作用域等等等等。
这个时候,我建议你就可以开始较系统的学习JS了。
方法可以是在网上,根据你听过却不了解但是又感兴趣的名词,搜索一些技术博客。
对一些基础知识,你也可以看看W3C School.http://www.w3school.com.cn/
但是,我认为最好的办法,是买一本好书来看,并跟着书的内容做一些练习。 有两本经典著作,我认为很适合作为JS入门:
《JavaScript高级程序设计》 (Prefessional JavaScript for Web Developers) 泽卡斯 (Zakas. Nicholas C.) (作者), 李松峰 (译者), 曹力 (译者)
《JavaScript权威指南(第六版)》 (JavaScript:The Definitive Guide,Sixth Edition) 弗兰纳根(David Flanagan) (作者), 淘宝前端团队 (译者)
入门的话,读其中一本就够了,也不一定要完全读完。 我只读过第一本, 我觉得把前面十章左右读完,并配合练习, 已经能解决工作中遇到的大部分问题,并能大致说出其中的原理了, 一般问题应该已经难不倒你。
到这时,我觉得你的JS已经算是入门了。
5. 修行在个人
入门只是学习的开始,这时你可以运用你的技能,实现各种需求。 在实现各种需求时,你会遇到更多各种各样的问题。
有些问题可能已经不是单纯写JS代码能很好解决的了。 你可能需要配合一些框架(jquery、angular等等),或一些工具(grunt、sass等等),或一些设计模式, 或一些业务知识。
随着解决更多问题, 你也会积累更多的知识。
之后会是漫长的积累过程, 通过项目经验、看书、看博客、思考、讨论等等,积累你的经验和知识。
你需要持之以恒和刨根问底。
总之,之后就看你自己的了。还是和前提差不多的那句话:你需要主动。
6. 最后, 推荐几个我认为好的网站或博客和一些我觉得不错的书(可能和上面有重复)
文档类:
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript
问答类:
大神博客:
http://www.cnblogs.com/cloudgamer/
http://www.cnblogs.com/rubylouvre/
不知如何归类:
书的话,已经有一篇博文(不完全关于JS)整理过了,直接上链接: http://www.cnblogs.com/bee0060/p/3972188.html
------------------------------------------------------------------
多谢观看
关于学习javascript的一些建议的更多相关文章
- 一步步学习javascript基础篇(7):BOM和DOM
一.什么是BOM.什么是DOM BOM即浏览器对象模型,主要用了访问一些和网页无关的浏览器功能.如:window.location.navigator.screen.history等对象. DOM即文 ...
- 一步步学习javascript基础篇(1):基本概念
一.数据类型 数据类型 基本数据类型(五种) Undefined Null Boolean Number String 复杂数据类型(一种) Object Undefined:只有一个值undefin ...
- 如何正确学习JavaScript
不要这样学习JavaScript 不要一开始就埋头在成堆的JavaScript在线教程里 ,这是最糟糕的学习方法.或许在看过无数个教程后会有点成效,但这样不分层次结构地学习一个东西实在是十分低效,在实 ...
- 「译」如何正确学习JavaScript
原文:How to Learn JavaScript Properly 目录 不要这样学习JavaScript 本课程资源 1-2周(简介,数据类型,表达式和操作符) 3~4周(对象,数组,函数,DO ...
- 学习javascript基础知识系列第二节 - this用法
通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...
- 学习javascript基础知识系列第三节 - ()()用法
总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...
- [转]如何正确学习JavaScript
原文:How to Learn JavaScript Properly(2014-2-7) 学习时长:6-8周 学习前提:中学水平,无需编程经验 更新(2014-1-7) 在Reddit上创建了一个学 ...
- 2、JavaScript 基础二 (从零学习JavaScript)
11.强制转换 强制转换主要指使用Number.String和Boolean三个构造函数,手动将各种类型的值,转换成数字.字符串或者布尔值. 1>Number强制转换 参数为原始类型值的转换规 ...
- 如何理解并学习javascript中的面向对象(OOP) [转]
如果你想让你的javascript代码变得更加优美,性能更加卓越.或者,你想像jQuery的作者一样,写出属于自己优秀的类库(哪怕是基于 jquery的插件).那么,你请务必要学习javascript ...
随机推荐
- C# Redis使用之StackExchange
第1章 安装 在.NET平台使用Redis需要做如下准备工作: 创建一个新的Visual Studio应用或者打开一个已经存在的Visual Studio应用. 打开NuGet程序包 搜索并添加S ...
- ASP.NET MVC 网站开发总结(四)——校友平台开发总结
又历经一个多月的努力,学校的一个校友平台项目也接近内测的尾声了,简单的总结一下这次的项目开发. 与上次做Wing工作室的门户网站相比,同样是团队开发,参与的人员多了一个,用的时间也差不多一个月,但从总 ...
- 阿里前端框架Alice是个不错的选择
BootStrap虽然用户群体广大,其整体风格尽管有不少skin可选,但以国情来看还是不好看. 阿里开源的前端框架,个人觉得还是很不错,Alice处处透着支付宝中界面风格的气息,电商感挺强. 以下内容 ...
- FPGA中的delay与latency
delay和latency都有延迟的意义,在FPGA中二者又有具体的区别. latency出现在时序逻辑电路中,表示数据从输入到输出有效经过的时间,通常以时钟周期为单位. delay出现在组合逻辑电路 ...
- ORM实现原理
1.什么是ORM ORM的全称是Object Relational Mapping,即对象关系映射.它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的 ...
- 性能测试学习之二 ——性能测试模型(PV计算模型)
PV计算模型 现有的PV计算公式是: 每台服务器每秒平均PV量 =( (总PV*80%)/(24*60*60*40%))/服务器数量 =2*(总PV)/* (24*60*60) /服务器数量 通过定积 ...
- 代理模式的java实现
1. 简介 代理模式(Proxy Pattern)是常用设计模式之一.代理模式的定义:Provide a surrogate or placeholder for another object to ...
- [AngularJS] 使用AngularCSS动态加载CSS
[AngularJS] 使用AngularCSS动态加载CSS 前言 使用AngularAMD动态加载Controller 使用AngularAMD动态加载Service 上列两篇文章里,介绍了如何如 ...
- apache EnableMMAP指令
官方说明地址:http://httpd.apache.org/docs/2.4/mod/core.html#enablemmap Use memory-mapping to read files du ...
- [转]Java中的事务
这篇Java事务的说明不错,所以把它转过来收藏了. 原博文地址:http://blog.csdn.net/gyf4817/article/details/5362444 通常的观念认为,事务仅与数据库 ...