javascript 数据结构和算法读书笔记 > 第一章 javascript的编程环境和模型
1.变量的声明和初始化
必须使用关键字 var,后跟变量名,后面还可以跟一个赋值表达式。
var name;
var age = 5;
var str = 'hello';
var flg = false;
2. javascript 中的算术运算和数学库函数
+(加)
- (减)
*(乘)
/ (除)
%(取余)
可以使用的数学库:

3. 判断结构
1) if else
2) switch
没有特别之处
4.循环结构
1)while
2) for
5. 函数
1)有返回值的
2)无返回值的
6. 变量作用域
变量作用域是指,一个变量在程序的哪些位置可以访问。
javascript中的变量作用域被定义为函数作用域,是指变量的值在定义该变量的函数内是可见的,并且在该函数内的嵌套函数中也可访问该变量。
言外之意就是指javascript中没有块级作用域(通过大括号{}来分割作用域的方式是无效的)。
function showScope(){
// 这里返回的是父级作用域里面的scope的值
return scope;
}
var scope = "global";
console.info(scope);// global
console.info(showScope());// global
上面的showScope中并没有定义scope这个变量,但是调用时依然反悔了global,就是业务在其父级作用域中定义过这个变量,这里将其返回。
function showScope(){
var scope = 'local'; // 在函数自己的作用域内定义scope变量
return scope;
}
var scope = 'global';
console.info(scope); // global
console.info(showScope()); // local
在函数内部自己定义了scope变量,返回时是返回自己作用域中的scope内容,和父级作用域中的同名变量无关。
function showScope(){
scope = 'local'; // 这里是修改了父级作用域中的scope值
return scope;
}
var scope = 'global';
console.info(scope); // global
console.info(showScope()); // local
console.info(scope); // global
在函数中没有定义新的scope变量,等于是修改了父级作用域中scope的值,所以在调用了一次showScope方法后,父级作用域中的scope的值也发生了改变。
7. 递归
先来看个求阶乘的函数
function factorial(number) {
if (number == 1) {
return number;
}else {
return number * factorial(number- 1);
}
}
console.info(factorial(5));
数字1的阶乘就是1本身,其他情况下都是这个数字number去乘以number-1的阶乘。
我通过自己的递归调用可以一直求到number=1时的阶乘为止, 如所示:
factorial(5) —> 5 * factorial(4) —> 5 * 4 * factorial(3) —> 5 * 4 * 3 * factorial(2) —> 5 * 4 * 3 * 2 * factorial(1) —> 5 * 4 * 3 * 2 * 1
8. 对象和面向对象编程
javascript也是一种面向对象的语言,我们可以定义对象,在其中设定私有、共有属性或方法,如下:
function Person(name, age){
var name = name; // private
this.age = age; // public
this.getName = function(){
return name;
};
}
在Person这个函数中,name为私有属性,在函数外是访问不到的;age为共有属性,其对象可以直接访问;getName()为共有方法,可以通过对象直接访问。
var john = new Person('john', 18);
john.age ->18
john.name -> undefined
john.getName() -> john
javascript 数据结构和算法读书笔记 > 第一章 javascript的编程环境和模型的更多相关文章
- javascript 数据结构和算法读书笔记 > 第二章 数组
这章主要讲解了数组的工作原理和其适用场景. 定义: 一个存储元素的线性集合,元素可以通过索引来任意存取,索引通常是数字,用来计算元素之间存储位置的偏移量. javascript数组的特殊之处: jav ...
- javascript 数据结构和算法读书笔记 > 第四章 栈
1. 对栈的操作 栈是一种特殊的列表,栈中的元素只能通过列表的一端进行访问,即栈顶.类似于累起一摞的盘子,只能最后被放在上面的,最先能被访问到. 就是我们所说的后入先出(LIFO). 对栈主要有入栈p ...
- javascript 数据结构和算法读书笔记 > 第五章 队列
队列是一种列表,但是它只能够在队尾插入元素,在队首删除元素.队列用于存储按照顺序排列的数据,先进先出.而栈则是后入栈的元素反而被优先处理. 实际中一般被应用在进程池.排队操作上面. 1. 队列的操作 ...
- javascript 数据结构和算法读书笔记 > 第三章 列表
1. 结构分析 列表首先要有以下几个属性: listSize 长度 pos 当前位置 dataStore 数据 我们要通过以下方法对上面三个属性进行操作: length() 获取长度 | getPos ...
- 《javascript权威指南》读书笔记——第一篇
<javascript权威指南>读书笔记——第一篇 金刚 javascript js javascript权威指南 由于最近想系统学习下javascript,所以开始在kindle上看这本 ...
- 为什么我要放弃javaScript数据结构与算法(第十一章)—— 算法模式
本章将会学习递归.动态规划和贪心算法. 第十一章 算法模式 递归 递归是一种解决问题的方法,它解决问题的各个小部分,直到解决最初的大问题.递归通常涉及函数调用自身. 递归函数是像下面能够直接调用自身的 ...
- 为什么我要放弃javaScript数据结构与算法(第七章)—— 字典和散列表
本章学习使用字典和散列表来存储唯一值(不重复的值)的数据结构. 集合.字典和散列表可以存储不重复的值.在集合中,我们感兴趣的是每个值本身,并把它作为主要元素.而字典和散列表中都是用 [键,值]的形式来 ...
- 为什么我要放弃javaScript数据结构与算法(第六章)—— 集合
前面已经学习了数组(列表).栈.队列和链表等顺序数据结构.这一章,我们要学习集合,这是一种不允许值重复的顺序数据结构. 本章可以学习到,如何添加和移除值,如何搜索值是否存在,也可以学习如何进行并集.交 ...
- 为什么我要放弃javaScript数据结构与算法(第五章)—— 链表
这一章你将会学会如何实现和使用链表这种动态的数据结构,这意味着我们可以从中任意添加或移除项,它会按需进行扩张. 本章内容 链表数据结构 向链表添加元素 从链表移除元素 使用 LinkedList 类 ...
随机推荐
- mysql模拟插入数据表
由于测试或者学习需要,我们要经常向一个新建的数据表插入几百万行以上的数据来验证我们的一些想法,比如索引的合理构建,表字段类型的设计等等,下面跟大家演示如何往一个新建的数据表插入N多条数据. 1.新建一 ...
- java中静态代码块的用法 static用法详解
(一)java 静态代码块 静态方法区别一般情况下,如果有些代码必须在项目启动的时候就执行的时候,需要使用静态代码块,这种代码是主动执行的;需要在项目启动的时候就初始化,在不创建对象的情况下,其他程序 ...
- Berkeley DB基础教程
一.Berkeley DB的介绍 (1)Berkeley DB是一个嵌入式数据库,它适合于管理海量的.简单的数据.如Google使用其来保存账户信息,Heritrix用其来保存froniter. (2 ...
- SQL Server中的PWDENCRYPT与PWDCOMPARE函数
前幾天有個客戶的網站出問題(不是我們開發的),請我們幫他看,主要的問題是他們的網站會員在進行查詢密碼時,會員收到信的時候在密碼的欄位竟然會出現 System.Binary[] 字樣.而我進去資料庫中查 ...
- Oracle数据库中如何选择合适的索引类型 .
索引就好象一本字典的目录.凭借字典的目录,我们可以非常迅速的找到我们所需要的条目.数据库也是如此.凭借Oracle数据库的索引,相关语句可以迅速的定位记录的位置,而不必去定位整个表. 虽然说,在表中是 ...
- Avoid The Lakes--poj3620
Avoid The Lakes Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7023 Accepted: 3735 D ...
- Macbook使用技巧
Mac OSX下 safari 常用快捷键盘 Command + R 刷新页面 Command + T 新建一个标签 Command + Shift+ 左右方向键 ...
- 【Linux CentOS 在虚拟机中XShell出现: (port 22): Connection failed.】
原因:没安装openssh-server组件!!!!!!!!!! 解决办法:yum install openssh-server 查看openssh-server是否启动: $:ps -ef |gre ...
- Asp.Net构架(Http请求处理流程)、Asp.Net 构架(Http Handler 介绍)、Asp.Net 构架(HttpModule 介绍)
转载: HttpHaddler,HttpModule http://blog.csdn.net/jiuqiyuliang/article/details/18713451 http://www.cnb ...
- ios控制器modal跳转
1. http://www.cnblogs.com/smileEvday/archive/2012/05/29/presentModalViewController.html 2012年5月- Pre ...