do-while语句是一种后测试循环语句do {statement} while (expression),至少会循环一次

while语句是一种前测试循环语句while (expression) statement

for语句也是一种前测试循环语句,它具有执行循环前初始变量,循环之后执行代码的能力

var count=10;

for (var i=0;i<count;i++)

{

  alert(i);

}

for-in语句是一种精准的迭代语句,用来枚举对象的属性for (property in expression) statement枚举的属性顺序因浏览器不同而有差异,property为属性,在for-in循环之前确认对象的值不是null或undefined

label语句可以在代码中添加标签,以便将来使用 label:statement

start:for (var i=0;i<count;i++)

{

alert(i);

}

break跳出循环

continue仅仅跳出本次循环

break和continue语句一般与label语句联合使用,从而返回代码中特定的位置

var num=0;

outermost:

for (var i=0;i<10;i++)

{

for ( var j=0;j<10;j++)

{

if  (i==5 && j=5)

{

break outermost;

}

num++;

}

}

alert(num); //55

with语句将代码的作用域设置到一个特定的对象中,是为了简化多次编写同一个对象的工作 with(expression) statement;

with(location)

{

var qs=search.substring(l);

var hostName=hostname;

var url=href;

}

上面例子意味着在with语句的代码块内部每个变量首先被认为是一个局部变量,严格模式下不允许使用with语句

switch语句里可以使用任何数据类型,每个case可以是变量、常量甚至是表达式

switch (expression)

{

case value :statement

  break;

case value : statement

  break;

case value :statement

  break;

default:statement

}

函数  function functionName(arg0,arg1,...argN)

{

statements

}

函数执行return语句后停止并立即退出,其后的代码不执行

ECMAScript中的参数在内部用一个数组表示,在函数体内可以通过arguments对象来访问参数数组,arguments.length属性获知有多少参数传递给了函数

function sayHi()

{

  alert("Hello"+arguments[0]+","+arguments[1]);

}

第4章  变量、作用域和内存问题

ECMAScript变量包含两种不同数据类型的值:基本类型值和引用类型值

基本类型值指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象

基本类型的值是按值访问,引用类型的值实际上是操作对象的引用而不是实际的对象是按引用访问的

只能给引用类型值动态添加属性,不能给基本类型值添加属性

对基本类型值复制时,分出的是两个独立的变量,而对于引用类型的值,复制的是一个指针地址,指向储存在堆中的一个对象,改变其中一个变量会影响到另一个变量

对函数的参数传递基本类型和引用类型同样遵循这个特性

//基本类型

function addTen(num)

{

  num+=10;

return num;

}

var count=20;

var result=addTen(count);

alert(count); //20,没有变化

alert(result); //30

//引用类型

function setName(obj)

{

obj.name="Nicholas";

}

var person = new object();

setName(person);

alert(person.name); //"Nicholas"

typeof 操作符是确定一个变量是字符串、数值、布尔值,还是undefined的最佳工具,如果变量的值是一个对象或者null,typeof操作符货返回"object"

var o = new object();

alert(typeof o); //object

ECMAScript提供了instanceof操作符检测对象的类型result=variable instanceof constructor

alert(person instanceof Object); //变量person 是Object 吗?

alert(colors instanceof Array); //变量colors 是Array 吗?

所有引用类型的值都是Object的实例,因此在检测一个引用类型值和Object构造函数时,instanceof始终返回true,检测基本类型的值时,始终返回false,因为基本类型不是对象

执行环境定义了变量或函数有权访问的其他数据,决定了他们各自的行为,每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量和函数都保存在这个对象中

全局执行环境是最外围的一个执行环境,在web浏览器中全局执行环境被认为是window对象,所有全局变量和函数都是作为window对象的属性和方法创建的,关闭网页会销毁全局执行环境

每个函数都有自己的执行环境,当执行流进入一个函数时,函数的环境就会被推入一个环境栈中,而在函数执行以后,栈将其环境弹出,把控制权返回给之前的执行环境

作用域链保证了对执行环境里的所有变量和函数的有序访问,作用域链开端是当前环境活动对象,即arguments对象,下一个变量对象包含来自外一层环境的活动对象,直至到全局执行环境

标识符解析时从前端一级一级往后解析,直到找到标识符为止,外部不能访问到内部

--------------------------------------------------------4.3任务-----------------------------------------------------------

JavaScript高级程序设计3.pdf的更多相关文章

  1. JavaScript高级程序设计61.pdf

    JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...

  2. JavaScript高级程序设计60.pdf

    错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...

  3. JavaScript高级程序设计58.pdf

    15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...

  4. JavaScript高级程序设计57.pdf

    表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...

  5. JavaScript高级程序设计55.pdf

    输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...

  6. JavaScript高级程序设计54.pdf

    过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...

  7. JavaScript高级程序设计53.pdf

    共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...

  8. JavaScript高级程序设计52.pdf

    表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...

  9. JavaScript高级程序设计50.pdf

    hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...

  10. JavaScript高级程序设计49.pdf

    HTML5事件 contextmenu事件 contextmenu事件是冒泡的,可以将事件处理程序指定到document,这个事件的目标是用户操作的元素,在兼容DOM的浏览器中使用event.prev ...

随机推荐

  1. CoreAnimation1-图层树、寄宿图以及图层几何学

    (一)图层的树状结构 Core Animation其实是一个令人误解的命名.你可能认为它只是用来做动画的,但实际上它是从一个叫做Layer Kit这么一个不怎么和动画有关的名字演变而来,所以做动画这只 ...

  2. winfrom面向对象1

    1:面向对象的技术概论 要学习好面向对象,我们应该从三个问题入手: 1.什么是面向对象? 2.为什么要面向对象? 3.该怎么面向对象? 对象的定义是人们要进行研究的任何事物,从最简单的整数到复杂的飞机 ...

  3. 开发中遇到的angularJs的小问题

    1.在使用自定义指令后如果需要将指令内部的数据传给外层controller需要设置scope属性,此时注意,如果指令内传出的数据在某种情况下需要清空,如传出一个选中元素的数组,点击清空按钮则清空选中这 ...

  4. linux上配置subversion服务器端安装配置并使用svn,windows本地检出,设置同步更新服务器的钩子

    参考http://my.oschina.net/junn/blog/164041 http://songxj.blog.51cto.com/620981/396113 http://5iwww.blo ...

  5. C#中标准Dispose模式的实现

    http://www.cnblogs.com/luminji/archive/2011/03/29/1997812.html 需要明确一下C#程序(或者说.NET)中的资源.简单的说来,C#中的每一个 ...

  6. tabBar选中底部弹出窗口

    //UITabBarControllerDelegate方法 - (BOOL)tabBarController:(UITabBarController *)tabBarController shoul ...

  7. 邮件协议POP3/IMAP/SMTP服务的区别

    2016年09月09日 09時51分 wanglinqiang整理 通过网上查找的资料和自己的总结完成了下面的文章,看完之后相信大家对这三种协议会有更深入的理解.如有错误的地方望指正. POP3 PO ...

  8. iOS 宏定义_16进制色值转化为RGB返回UIColor类型对象

    // 十六进制颜色 #define COLOR_WITH_HEX(hexValue) [UIColor colorWithRed:((float)((hexValue & 0xFF0000) ...

  9. python关键字

    python有多少关键字? >>> import keyword >>> keyword.kwlist ['and', 'as', 'assert', 'break ...

  10. Contest20140710 sequence

    sequence|sequence.in|sequence.out 题目描述: 给定一个整数K和长为N的数列{Ai},求有多少个子串(不含空串)的和为K的倍数.(在这里子串表示{A[i]..A[j]} ...