好文档 - 专业文书写作范文服务资料分享网站

Javascript学习笔记自学实用

天下 分享 时间: 加入收藏 我要投稿 点赞

JavaScript学习笔记

一. 基础篇

Javascript学习笔记1——数据类型

在Javascript中只有五种简单类型,分别为null,undefined,boolean,String和Number.一种复杂类型:object。

代码类型只有一种形式就是function。

undefined:未定义,我们也可称之为不存在,typeof(undefined)=undefined.

null:为空。undefined是不存在,而null是存在,但却无。typeof(null)=object,但null又不是object,这就是null的神奇而独特之处。 boolean:true or false。

Number:NaN和Infinity是两个特殊之数,NaN代表一个无法用数值来表示的数字,而Infinity代表一个无穷大的数字,相对的,-Infinify则代表负无穷大。在此有两点特殊的地方:NaN!=NaN,Infinity/Infinity=NaN。在Number类型中,有个非常有用的方法:ToString(),他可以接受一个从2到36的数字,然后把我们的Number转换为相应的进制数。

String:字符串,Javascript中没有字符的概念,字符串是表示文本的最小单位。在字符串中,有这样的两个函数,分别是charAt(index)和charCodeAt(index)分别返回对应索引的字符和字符Unicode编码。在我们平时,可能经常会使用下标的方式访问,如s[10],可是这并不是ECMAScript的标准,应该尽量避免。

Javascript的一切类型都是基于这五个简单类型向上搭建。这五个类型之间又有着万千复杂的关

系,undefined,null,0,“”转换为boolean时就是false,而除去这四个外,所有的都为true。但是在这五个当中,除了undefined==null,其他又都不相等。

我们在此又有着这样和强类型语言不通之处,例如123==“123”。那么我们如何能够区分类型呢?这个时候:全等于:===就发挥了用场。

Javascript学习笔记2——函数

在Javascript中,function才是Javascript的第一型。当我们写下一段函数时,其实不过是建立了一个function类型的实体。 就像我们可以写成这样的形式一样:

functionHello() {

alert(\); } Hello();

varHello = function() { alert(\); } Hello();

其实都是一样的。

但是当我们对其中的函数进行修改时,会发现很奇怪的问题。

functionHello() { alert(\); } Hello();

functionHello() { alert(\); } Hello();

我们会看到这样的结果:连续输出了两次Hello World。而非我们想象中的Hello和Hello World。

这是因为Javascript并非完全的按顺序解释执行,而是在解释之前会对Javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有var变量创建,默认值为undefined,以提高程序的执行效率。也就是说上面的一段代码其实被JS引擎预编译为这样的形式:

varHello = function() { alert(\); }

Hello = function() { alert(\); } Hello(); Hello();

我们可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:

functionHello() { alert(\); } Hello();

functionHello() { alert(\);

} Hello();

这样,程序被分成了两段,JS引擎也就不会把他们放到一起了。

Javascript学习笔记3——作用域

每个写过程序的人都不会对作用域这个概念陌生,那在这篇文章中就来谈下Javascript的作用域。

在Javascript,全局环境本身就一个对象。在浏览器宿主中这个对象是window,而当Javascript用于其它非浏览器的宿主,如嵌入式的环境中,可能会是其它的对象。

在这里也纠正一个观念,有很多人都认为Javascript只在浏览器中使用,其实Javascript也能在很多非Web情况下使用,据介绍Javascript在一些基于嵌入式的应用领域表现得也很出色,当然这些我也只是听过传说而已。

言归正传,当我们写下:var i=1时,其实就是声明了一个window作用域的一个变量。 而当我们写下i=1时,是声明了一个window的属性。 看这样一段代码:

vara = \; b = \; Test();

functionTest() { alert(a + \+ b); vara = \; b = \;

alert(a + \+ b); }

alert(a + \+ b);

这段代码分别输出的结果是:undefined world,welcome china, hello china. 我们来分别解释:

在上文中,我们说过,在Javascript预编译时,会把所有var变量创建,默认值为undefined,我们在这里可以举一个例子: 我们可以写这样一段代码:

alert(a); alert(b); vara = \; b = \;

当我们执行运行这段脚本时,可以发现,首先弹出undefined,然后回提示脚本错误,提示b不存在。由此就可以表明,a在预编译的过程中就已经被创建并且初始化为undefined,而b却只能在实际运行时按顺序去解释。其实在预编译后的Javascript代码可以近乎理解如下:

vara = undefined; alert(a); alert(b); a = \; b = \;

92wb26royh1cf865breu5a66i6tmb7010sm
领取福利

微信扫码领取福利

微信扫码分享