JavaScript极简入门教程(一):基础篇


Posted in Javascript onOctober 25, 2014

阅读本文需要有其他语言的编程经验。

开始学习之前

大多数的编程语言都存在好的部分和差的部分。本文只讲述 JavaScript 中好的部分,这是因为:

1.仅仅学习好的部分能够缩短学习时间
2.编写的代码更加健壮
3.编写的代码更加易读
4.编写的代码更加易于维护

弱类型和强类型

通常来说,越早的修复错误,为之付出的代价就越小。强类型语言的编译器可以在编译时检查某些错误。而 JavaScript 是一门弱类型语言,其解释器无法检查类型错误,但实践表明:

1.强类型能够避免的错误并不是那些关键性错误
2.弱类型能够带来灵活性,也无需背上强类型的包袱

JavaScript 相关标准

ECMA-262 标准定义了语言 ECMAScript。我们所熟知的 JavaScript 和 ActionScript 都是基于 ECMAScript 的。目前主流使用 ECMA-262 第五版,Google 的 V8 引擎就是对此的实现。

Hello JavaScript

JavaScript 是一门脚本语言,需要解释器解释执行。你可以在浏览器中解释执行 JavaScript 或者直接使用 node.js,node.js 整合了 Google 的 V8 JavaScript 引擎。由于 node.js 使用非常方便,由此,这里我使用 node.js 来解释执行 JavaScript。现在看第一个 JavaScript 程序:

// test.js

console.log("Hello JavaScript");

执行此程序:

node test.js

语法

注释

JavaScript 使用和 C++ 相同的注释方式,// 用于单行注释,/* */ 用于多行注释。

数字类型

JavaScript 仅有一种数字类型,也就是 64 位浮点数。数字类型有两个特殊的值 NaN 和 Infinity,NaN 的含义为 not a number(不是一个数),使用函数 isNaN 检查是否为 NaN,值 Infinity 表示无穷大。在 Math 对象中,有一组操作数字的方法,例如:Math.floor 方法用于向下取整。

字符串

字符串 literal 可以被包裹在单引号或者双引号中,转义字符使用 \(和其他很多语言没有什么不同)。JavaScript 中每个字符都是两个字节,其使用 Unicode 字符集。字符串有一个 length 属性:

"Hello".length // 值为 5,注意不是 "Hello".length()

字符串是不可以改变的(和 Lua 一样),除了这里说的 length 属性,还有一些方法,例如:

'cat'.toUpperCase() === 'CAT'

语句

var 语句用于声明局部变量,否则变量为全局变量,未初始化的变量的值为 undefined:

function f() {

    var localVar = 123;

    globalVar = 456;

    var i; // i 的值为 undefined

};

 

f();

 

console.log(globalVar); // ok

console.log(localVar); // 错误,localVar 没有被定义

由 {} 包裹的一组语句被叫做语句块(Block),和其他语言不同的是,JavaScript 中的函数会而块不会创建新的作用域,例如:

{

    var v = 123;

}

console.log(v); // ok

if 语句

if (expression)

    statement

或者

if (expression)

    statement1

else

    statement2

或者

if (expression1)

    statement1

else if (expression2)

    statement2

else if (expression3)

    statement3

else

    statement4

if 语句通过判断表达式的值为真或假来决定执行或者跳过某些语句。在 JavaScript 中以下值为假(其他值均为真):

1.false
2.null
3.undefined
4.空字符串
5.0
6.NaN

if 中的 statement 可以是一个语句,也可以是一个语句块。

switch 语句

switch (n) {

    case 1: // 如果 n 等于 1

    // 执行代码块

    break;

    case 2: // 如果 n 等于 2

    // 执行代码块

    break;

    default: // 如果 n 不为 1 也不为 2

    // 执行代码块

    break;

}

这里的 break 用于退出循环语句或者 switch 语句。在 JavaScript 中,比较两个值是否相等有两个操作符:

1.==(对应 != 操作符),相等,两个操作数类型不同时,此运算符尝试操作数类型转换后再进行比较,例如:

var x = 1;

x == 1; // true

x == "1"; // true

2.===(对应 !== 操作符),完全相等,比较两个操作数,不进行操作数类型转换,例如:

var x = 1;

x === 1; // true

x === "1"; // false

需要注意的是 NaN 和任何值都不相等,如果 x 为 NaN,那么 x !== x(仅对 NaN 成立),我们可以这样实现 isNaN 函数:

function isNaN(n) {

    return n !== n;

}

上面 switch 语句,转换为 if 语句为:

if (n === 1)

    // ...

else if (n === 2)

    // ...

else

    // ...

while 和 do-while 语句

while (expression)

    statement

如果 expression 为真则重复执行 statement 直到 expression 为假。

do

    statement

while (expression);

类似 while 循环,只是先执行 statement,然后再检查条件 expression。

for 语句

for (initialize ; test ; increment)

    statement

首先 initialize 被执行一次(常用来初始化循环变量),然后进行 test 条件测试(常用来测试循环变量),如果 test 条件为假则停止循环,否则执行 statement,然后执行 increment(常用来更新循环变量),接着又进行 test 条件测试,如此循环执行下去。使用范例:

for (var i=0; i<5; ++i) {

    console.log(i);

}

for 的另外一种形式被用于枚举一个对象的所有属性名:

for (variable in object)

    statement

范例:

var obj = {

    a: 1,

    b: 2,

    c: 3

};

 

for (var name in obj)

    console.log(name);

需要注意的是,我们通过 hasOwnProperty 方法来检查属性名是该对象的,还是从原型链(prototype chain,prototype 会在 下一篇 中介绍)中找到的:
for (var in obj) {

    if (obj.hasOwnProperty(var)) {

        // ...

    }

}

return 语句

return 语句用于让函数返回一个值,如果函数没有显式的使用 return,那么返回 undefined:

function f() { }

var v = f(); // v === undefined

?: 条件操作符(JavaScript 中唯一的一个三元操作符)
?: 条件操作符在很多编程语言中都存在,在第一个操作数为真时,操作符返回第二个操作数的值,否则返回第三个操作数的值,使用范例:

function abs() {

    return x > 0 ? x : -x;

}

typeof 操作符

typeof 操作符用于获取变量的类型,其返回值包括:

1.'number'
2.'string'
3.'boolean'
4.'undefined'
5.'function'
6.'object'

特别的 typeof null 返回的结果是 'object'。关于 typeof 的范例:

var a = typeof 'hello'; // a === 'string'

var b = typeof null; // b === 'object'

+ 操作符

+ 操作符在 JavaScript 中可以用于加法运算,也可以用于字符串连接:

var message = 'hello' + 'world'; // message === 'helloworld'

&& 和 || 运算符

&& 操作符在第一个操作数为假时返回第一个操作数的值,否则返回第二个操作数的值
|| 操作符在第一个操作数为真时返回第一个操作数的值,否则返回第二个操作数的值

var a = 1 && true; // a === true

var b = 1 || false; // b === 1

|| 的一个习惯用法:

name = name || 'unknown'; // 为 name 设定默认值 'unknown'
Javascript 相关文章推荐
JavaScript 封装Ajax传递的数据代码
Jun 05 Javascript
js屏蔽鼠标键盘(右键/Ctrl+N/Shift+F10/F11/F5刷新/退格键)
Jan 24 Javascript
iframe如何动态创建及释放其所占内存
Sep 03 Javascript
js正则表达式中exec用法实例
Jul 23 Javascript
百度坐标(BD09)、国测局坐标(火星坐标,GCJ02)、和WGS84坐标系之间的转换
Feb 19 Javascript
浅析jquery如何判断滚动条滚到页面底部并执行事件
Apr 29 Javascript
详解Node.js模块间共享数据库连接的方法
May 24 Javascript
Angular学习笔记之angular的$filter服务浅析
Nov 12 Javascript
微信小程序实现默认第一个选中变色效果
Jul 17 Javascript
vue使用laydate时间插件的方法
Nov 14 Javascript
如何在CocosCreator里画个炫酷的雷达图
Apr 16 Javascript
Vue2项目中对百度地图的封装使用详解
Jun 16 Vue.js
上传图片预览JS脚本 Input file图片预览的实现示例
Oct 23 #Javascript
实用框架(iframe)操作代码
Oct 23 #Javascript
form.submit()不能提交表单的原因分析
Oct 23 #Javascript
Google Maps API地图应用示例分享
Oct 23 #Javascript
深入分析JQuery和JavaScript的异同
Oct 23 #Javascript
jquery实现导航固定顶部的效果仿蘑菇街
Oct 22 #Javascript
用jquery模仿的a的title属性的例子
Oct 22 #Javascript
You might like
php中使用ExcelFileParser处理excel获得数据(可作批量导入到数据库使用)
2010/08/21 PHP
30 个很棒的PHP开源CMS内容管理系统小结
2011/10/14 PHP
JavaScript开发时的五个注意事项
2007/12/08 Javascript
JS 用6N±1法求素数 实例教程
2009/10/20 Javascript
解决html按钮切换绑定不同函数后点击时执行多次函数问题
2014/05/14 Javascript
Jquery使用css方法改变样式实例
2015/05/18 Javascript
jQuery图片旋转插件jQueryRotate.js用法实例(附demo下载)
2016/01/21 Javascript
javascript基本语法
2016/05/31 Javascript
JS实现倒计时(天数、时、分、秒)
2016/11/16 Javascript
利用jquery实现下拉框的禁用与启用
2016/12/07 Javascript
webuploader模态框ueditor显示问题解决方法
2016/12/27 Javascript
js代码延迟一定时间后执行一个函数的实例
2017/02/15 Javascript
小程序实现发表评论功能
2018/07/06 Javascript
Angular(5.2-&gt;6.1)升级小结
2018/12/27 Javascript
从0到1搭建element后台框架优化篇(打包优化)
2019/05/12 Javascript
SSM+layUI 根据登录信息显示不同的页面方法
2019/09/20 Javascript
paramiko模块安装和使用(远程登录服务器)
2014/01/27 Python
使用python将mdb数据库文件导入postgresql数据库示例
2014/02/17 Python
利用Python爬取可用的代理IP
2016/08/18 Python
python3+PyQt5实现拖放功能
2018/04/24 Python
Pycharm取消py脚本中SQL识别的方法
2018/11/29 Python
Python3.5字符串常用操作实例详解
2019/05/01 Python
python解析xml简单示例
2019/06/21 Python
python爬虫 模拟登录人人网过程解析
2019/07/31 Python
惠普加拿大在线商店:HP加拿大
2017/09/15 全球购物
Asics日本官网:鬼冢八喜郎创立的跑鞋运动品牌
2017/10/18 全球购物
美国益智玩具购物网站:Fat Brain Toys
2017/11/03 全球购物
美国保健品专家:Life Extension
2018/05/04 全球购物
Viking Direct荷兰:购买办公用品
2019/06/20 全球购物
英国领先的独立时装店:Van Mildert
2019/10/28 全球购物
如何利用find命令查找文件
2016/11/18 面试题
房地产融资计划书
2014/01/10 职场文书
劳动模范事迹材料
2014/01/19 职场文书
11月升旗仪式讲话稿
2014/02/15 职场文书
2015年安全月活动总结
2015/03/26 职场文书
小学思想品德教学反思
2016/02/24 职场文书