走出JavaScript初学困境—js初学


Posted in Javascript onDecember 29, 2008

从开始接触JS这东西有一年时间了,心头总是有一些说不出来的苦闷。在论坛里也常常有人这么说。那么苦在何处呢?总是感觉学的不深入,一些简单的东西可以做但也是不能得心应手。能不能把这种苦再说的具体点儿呢?都说了是“说不出来的苦闷”怎么具体呀?

何为难言之隐?说不出来,不能具体,不能把问题落到实处就不能得到解决的办法。这就是难言之隐!我认为这也就是初学者的“困境”。之所以要用“我认为”正好迎合了本文标题中的“心得”二字。如果能对大家有帮助我非常高兴。

下面言归正传,我经过回想和思考总结出下面几条初学者的“难言之隐”大家看看有没有说到我们的心坎儿上,呵呵。

一、用系统的知识将问题具体化

我们在学习时经常会发现可以用不同的方法来实现同一个问题。例如,要为元素绑定一个点击事件可以在HTML元素上用<a href="#" onClick="f1()"></a>,我们起初会认为这就是绑定事件的方法。

当我们第二次又看到可以将一个函数传递给一个事件来绑定:a.onclick=f1;这时我们又会想原来绑定事件不只有一种方法。

当我们第三次又看到用addachEvent("onclick",f1)这种方法绑定事件的时候,你一定会想绑定事件的方法可能不只这三种。而且做一件事没理由要三种相同的方法,他们之间一定有不同之处?

那么他们有什么不同之处呢?到底绑定事件有多少种方法呢?当你发现一种方法在IE中不兼容的时候你还会问这到底是为什么呢?是我的语法错误了吗?还是怎么回事。一个又一个的问题结束之后你只好问自己:“天呀!我什么时候才能学好JavaScript呢?!“。

可能这样下去你很难学好JS。其实还要告诉你,你离学好他并不远了,只是你不知道怎么走。原因在哪里?原因就是没有系统的知识,原因就是没有读过《JavaScript权威指南》,他会告诉你绑定事件有四种方法,并且有两种是基本方法,所有浏览器都支持他,另外还有两种高级方法,一种是W3C标准方法,一种是IE标准方法,所以你知道为什么IE不兼容其中的一种高级方法了,对吗?

现在事情具体化了,绑定一个事件的时候只需考虑这四种方法,你也不会再有那么多的疑惑了。你也会觉得自己弄懂事件了,下一步你应该去弄懂其它问题了,你还会觉得自己在JS方面终于有进展了,当然你还会感觉到走出一个困境了。

二、必需了解JavaScript的历史

你了解JS的历史吗?我当然了解,他原本不叫JavaScript,他最早不是实现在IE中的。对,说的很好,可这不是最重要的,知道这个也不会成为高手,你必须了解的更详细,而且主要是了解功能进化方面的历史。

就像上面,为什么绑定事件会有那多的方法?为什么获得一个元素会有那么多的方法?倒底是document.links[]正规一点?还是getElementsByTagName('a')正规一点?哪一个兼容性更好?还有多少这样的方法?

要知道一个问题就够头痛了,十个问题你就无从下手,一百个问题你就会怀疑自己。一千个问题最后又回到那个问题“天呀!我什么时候才能学好JavaScript“?呵呵,事情往往就是这样。解决的方法就是具体化他,去弄懂到底有几种方法,为什么又有这些方法。这些问题一定会有答案,因为JS不是外星人留下的东西,是人创造出来的,而那个人的思维也是有限的,不是吗?

当你知道document.links[]是遗留的document方法,而且这种遗留方法一共有5个。分别是anchors[],applets[],forms[],images[],links[]的时候有些问题就消失了,当你还知道DOM标准保留了他们,你还知道所有浏览器都支持他们,你还知道他们就是所谓的“0级DOM”你又会走出一个“困境”。

三、JS有纵横交错的知识结构

JS的知识结构是横向和纵向交错的,这加大了理解他的难度,对这一点必需有一个清晰的认识。下面解释一下“纵横交错”。

一般的知识都有横向性。比如从大的方面JS分为核心部分和客户端部分。这是横向。核心部分又分为词法结构,数据类型和值,变量,表达式和运算符,语句,对象和数组,函数,类,模块和名字空间,正则表达式。这也是横向。

客户端部分可以分为BOM,DOM,事件,样式,表单等,这些也是横向的知识结构。

一门技术很少用时间作为结构,但因为浏览器的发展是动态的,不同时期的浏览器对JS有不同程度的实现,而在不同时间针对当时浏览器所编写的网页不能因为技术的发展就不去考虑他,而且让所有的网站都随着技术的发展而重新编写是不可能的,所以JS即要发展升级,也要保留向前的支持。所以就算有了更好的方法也必需保留之前的方法,就有了好多遗留的JS属性和方法,比如“0级DOM”在新的W3CDOM中得到了保留,从某种程度来讲他就是纵向的。

当对知识结构有了清楚的认识,会有一个好处就是当我要解决一个问题的时候我就能知道我要用的是哪一块的知识。比如要得到一个元素在文档中的位置就会知道用的是DOM中元素的属性,要得到鼠标指针的位置就要用事件对象的属性。要获得一个元素的引用可以用遗留的DOM也可以用W3C标准的DOM方法。这是件好事。

其实上面问题的核心就是系统化和具体化,这是我在学习过程中觉得很重要的一点。这一点确实为我解决了不少疑惑。

走出初学困境,我们需要系统的知识和具体化的思想。谢谢你能花时间读这篇文章希望能对你有帮助。如果想讨论更多的问题,欢迎加我的QQ:303551651。

Javascript 相关文章推荐
ASP.NET jQuery 实例9  通过控件hyperlink实现返回顶部效果
Feb 03 Javascript
JQuery表格内容过滤的实现方法
Jul 05 Javascript
在Linux上用forever实现Node.js项目自启动
Jul 09 Javascript
JavaScript中数组继承的简单示例
Jul 29 Javascript
jQuery解决$符号命名冲突
Jun 18 Javascript
JS仿京东移动端手指拨动切换轮播图效果
Apr 10 Javascript
JavaScript校验Number(4,1)格式的数字实例代码
Mar 13 Javascript
js实现input密码框显示/隐藏功能
Sep 10 Javascript
Vue指令v-for遍历输出JavaScript数组及json对象的常见方式小结
Feb 11 Javascript
vue项目中实现缓存的最佳方案详解
Jul 11 Javascript
vue 实现购物车总价计算
Nov 06 Javascript
JS封装cavans多种滤镜组件
Feb 15 Javascript
ExtJS 简介 让你知道extjs是什么
Dec 29 #Javascript
不用写JS也能使用EXTJS视频演示
Dec 29 #Javascript
My Desktop :) 桌面式代码
Dec 29 #Javascript
Ext第一周 史上最强学习笔记---GridPanel(基础篇)
Dec 29 #Javascript
extjs grid取到数据而不显示的解决
Dec 29 #Javascript
extjs form textfield的隐藏方法
Dec 29 #Javascript
Javascript valueOf 使用方法
Dec 28 #Javascript
You might like
smarty模板中拼接字符串的方法
2014/02/14 PHP
php定义一个参数带有默认值的函数实例分析
2015/03/16 PHP
PHP+MYSQL中文乱码问题
2015/07/01 PHP
yii2框架中使用下拉菜单的自动搜索yii-widget-select2实例分析
2016/01/09 PHP
php 判断过去离现在几年的函数(实例代码)
2016/11/15 PHP
PHP使用第三方即时获取物流动态实例详解
2017/04/27 PHP
php实现和c#一致的DES加密解密实例
2017/07/24 PHP
使用PHPUnit进行单元测试并生成代码覆盖率报告的方法
2019/03/08 PHP
Ctrl+Enter提交内容信息
2006/06/26 Javascript
Autocomplete Textbox Example javascript实现自动完成成功
2007/08/17 Javascript
jquery 获取 outerHtml 包含当前节点本身的代码
2014/10/30 Javascript
45个JavaScript编程注意事项、技巧大全
2015/02/11 Javascript
jQuery实现的网格线绘制方法
2016/06/20 Javascript
javascript 面向对象function详解及实例代码
2017/02/28 Javascript
关于vue.js过渡css类名的理解(推荐)
2017/04/10 Javascript
vue组件如何被其他项目引用
2017/04/13 Javascript
React Native如何消除启动时白屏的方法
2017/08/08 Javascript
[01:14]英雄,所敬略同——2018完美盛典宣传视频4K
2018/12/05 DOTA
python实现忽略大小写对字符串列表排序的方法
2014/09/25 Python
对python requests发送json格式数据的实例详解
2018/12/19 Python
Python matplotlib以日期为x轴作图代码实例
2019/11/22 Python
python字典和json.dumps()的遇到的坑分析
2020/03/11 Python
keras 简单 lstm实例(基于one-hot编码)
2020/07/02 Python
美国球鞋寄卖网站:Stadium Goods
2018/05/09 全球购物
婴儿地球:Baby Earth
2018/12/25 全球购物
英国家庭家具、照明和花园家具购物网站:Furniture123
2018/12/31 全球购物
英国川宁茶官方网站:Twinings茶
2019/05/21 全球购物
英国拖鞋购买网站:Bedroom Athletics
2020/02/28 全球购物
学雷锋演讲稿
2014/03/04 职场文书
文科毕业生自荐书范文
2014/04/17 职场文书
捐款活动总结
2014/08/27 职场文书
Python Django框架介绍之模板标签及模板的继承
2021/05/27 Python
MySql开发之自动同步表结构
2021/05/28 MySQL
Vue实现跑马灯样式文字横向滚动
2021/11/23 Vue.js
mysql 8.0.27 绿色解压版安装教程及配置方法
2022/04/20 MySQL
html用代码制作虚线框怎么做? dw制作虚线圆圈的技巧
2022/12/24 HTML / CSS