没有合适的资源?快使用搜索试试~ 我知道了~
Javascript学习笔记【自学实用文档】
5星 · 超过95%的资源 需积分: 9 112 下载量 89 浏览量
2013-01-17
23:32:24
上传
评论 2
收藏 1.65MB DOC 举报
温馨提示
Javascript学习笔记_自学实用 原创笔记,整理得很不错,适合初学者,推荐大家!
资源推荐
资源详情
资源评论
JavaScript 学习笔记
一. 基础篇
Javascript
学习笔记
1—— 数据类型
在 Javascript 中只有五种简单类型,分别为 null,undened,boolean,String 和 Number.一
种复杂类型:object。
代码类型只有一种形式就是 function。
undened:未定义,我们也可称之为不存在,typeof(undened)=undened.
null:为空。undened 是不存在,而 null 是存在,但却无。typeof(null)=object,但 null 又
不是 object,这就是 null 的神奇而独特之处。
boolean:true or false。
Number:NaN 和 Innity 是两个特殊之数,NaN 代表一个无法用数值来表示的数字,而
Innity 代表一个无穷大的数字,相对的,-Innify 则代表负无穷大。在此有两点特殊的地方:
NaN!=NaN , Innity/Innity=NaN 。 在 Number 类 型 中 , 有 个 非 常 有 用 的 方 法 :
ToString(),他可以接受一个从 2 到 36 的数字,然后把我们的 Number 转换为相应的进制数。
String:字符串,Javascript 中没有字符的概念,字符串是表示文本的最小单位。在字符串中,
有这样的两个函数,分别是 charAt(index)和 charCodeAt(index)分别返回对应索引的字符和
字符 Unicode 编码。在我们平时,可能经常会使用下标的方式访问,如 s[10],可是这并不是
ECMAScript 的标准,应该尽量避免。
Javascript 的一切类型都是基于这五个简单类型向上搭建。这五个类型之间又有着万千复杂的
关系,undened,null,0,“”转换为 boolean 时就是 false,而除去这四个外,所有的都为
true。但是在这五个当中,除了 undened==null,其他又都不相等。
我们在此又有着这样和强类型语言不通之处,例如 123==“123”。那么我们如何能够区分类
型呢?这个时候:全等于:===就发挥了用场。
Javascript
学习笔记
2—— 函数
在 Javascript 中,function 才是 Javascript 的第一型。当我们写下一段函数时,其实不过是
建立了一个 function 类型的实体。
就像我们可以写成这样的形式一样:
functionHello() {
alert("Hello");
}
Hello();
varHello = function() {
alert("Hello");
}
Hello();
其实都是一样的。
但是当我们对其中的函数进行修改时,会发现很奇怪的问题。
<scripttype="text/javascript">
functionHello() {
alert("Hello");
}
Hello();
functionHello() {
alert("Hello World");
}
Hello();
</script>
我们会看到这样的结果:连续输出了两次 Hello World。而非我们想象中的 Hello 和 Hello
World。
这是因为 Javascript 并非完全的按顺序解释执行,而是在解释之前会对 Javascript 进行一次
“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有 var 变量创建,默认
值为 undened,以提高程序的执行效率。也就是说上面的一段代码其实被 JS 引擎预编译为
这样的形式:
<scripttype="text/javascript">
varHello = function() {
alert("Hello");
}
Hello = function() {
alert("Hello World");
}
Hello();
Hello();
</script>
我们可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数
“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:
<scripttype="text/javascript">
functionHello() {
alert("Hello");
}
Hello();
</script>
<scripttype="text/javascript">
functionHello() {
alert("Hello World");
}
Hello();
</script>
这样,程序被分成了两段,JS 引擎也就不会把他们放到一起了。
Javascript
学习笔记
3—— 作用域
每个写过程序的人都不会对作用域这个概念陌生,那在这篇文章中就来谈下 Javascript 的作用
域。
在 Javascript,全局 环境本 身就一 个对象 。在浏 览器宿 主中这 个对象 是 window,而 当
Javascript 用于其它非浏览器的宿主,如嵌入式的环境中,可能会是其它的对象。
在这里也纠正一个观念,有很多人都认为 Javascript 只在浏览器中使用,其实 Javascript 也
能在很多非 Web 情况下使用,据介绍 Javascript 在一些基于嵌入式的应用领域表现得也很出
色,当然这些我也只是听过传说而已。
言归正传,当我们写下:var i=1 时,其实就是声明了一个 window 作用域的一个变量。
而当我们写下 i=1 时,是声明了一个 window 的属性。
看这样一段代码:
<scripttype="text/javascript">
vara = "hello";
b = "world";
Test();
functionTest() {
alert(a + " "+ b);
vara = "welcome";
b = "china";
alert(a + " "+ b);
}
alert(a + " "+ b);
</script>
这段代码分别输出的结果是:undened world,welcome china, hello china.
我们来分别解释:
在 上 文 中 , 我 们 说 过 , 在 Javascript 预 编 译 时 , 会 把 所 有 var 变 量 创 建 , 默 认 值 为
undened,我们在这里可以举一个例子:
我们可以写这样一段代码:
<scripttype="text/javascript">
alert(a);
alert(b);
vara = "111";
b = "111";
</script>
当我们执行运行这段脚本时,可以发现,首先弹出 undened,然后回提示脚本错误,提示 b
不存在。由此就可以表明,a 在预编译的过程中就已经被创建并且初始化为 undened,而 b
却只能在实际运行时按顺序去解释。其实在预编译后的 Javascript 代码可以近乎理解如下:
<scripttype="text/javascript">
vara = undened;
alert(a);
alert(b);
a = "111";
b = "111";
</script>
接下来我们可以谈一下函数的作用域问题,每当代码运行进入一个函数时,Javascript 引擎就
会自动创建一个新的作用域,然后把这个新作用域作为当前作用域的子作用域,然后把当前的
代码作用域切换到这个新作用域。当代码退出函数时,这个作用域销毁,把代码作用域交还给
他的父作用域。
好,准备工作差不多了,接下来我们就来解释第一个问题:问什么会输出 undened world。
首先代码进行在预编译,当进入 Test 方法时,开启一个新作用域,然后把全局作用域作为他的
父作用域。然后对 Test 内的方法进行预编译,和上面的代码一样,Test 方法被预编译后方法
体大致如下:
functionTest() {
vara = undened;
alert(a + " "+ b);
vara = "welcome";
b = "china";
alert(a + " "+ b);
}
当然,在当前作用域下无法找到 b,于是他就会到他的父作用域下,也就是全局作用域找到了
b=“world”。于是也就产生了这样的结果。
第二次弹出 welcome china,没什么好说的。
第三次,弹出 hello china。我们可以这样理解,var a 只是 方法 Test 的一个局部变量,而 b
由于事先未声明,因此他会去父作用域中去找到对应的定义。
好,接下来,我们再看一下这个方法的若干个变体。
<scripttype="text/javascript">
vara = "hello";
b = "world";
Test();
functionTest() {
alert(a + " "+ b);
a = "welcome";
b = "china";
alert(a + " "+ b);
}
alert(a + " "+ b);
</script>
首先,我们将方法体内的 var a 改成 a,我们先不看答案,直接来分析,首先,在预编译阶段,
方法体内几乎没有任何改变,因此此时 a 和 b 一样,都要去他们的父作用域中去寻找,因此第
一次出的结果应该是 hello world,第二次没什么说的:welcome china,第三次由于 a 和 b
在本作用域内都没有事先定义,因此都是再改变父作用域内的值,因此应该输出 welcome
china.
剩余46页未读,继续阅读
lx76939412
- 粉丝: 261
- 资源: 392
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
- 1
- 2
前往页