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. 工具: ass109.awk 分析 Oracle 的跟踪文件

    原文链接:http://www.eygle.com/archives/2009/11/awk_ass109.html 以前分析Oracle的跟踪文件,主要靠手工阅读,最近发现ass109.awk文件是 ...

  2. Jquery插件之信息弹出框showInfoDialog(成功、错误、警告、通知)

    一.信息种类说明: 1.1.操作成功信息 1.2.错误信息 1.3.警告信息 1.4.通知信息 二.使用说明 <!DOCTYPE html PUBLIC "-//W3C//DTD HT ...

  3. Qt XML的使用

    Qt中对于XML文件的写入有两种方式,一个是使用QXmlStreamWriter,另一个则为使用Dom.stream流的形式相对来说更加灵活,而且适合处理大文件.Dom方式由于是将内容加载到了内存中进 ...

  4. [Neural Networks] Dropout阅读笔记

    多伦多大学Hinton组 http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf 一.目的 降低overfitting的风险 二.原理 ...

  5. MyEclipse使用经验总结

    0.快捷键 ================================================================================ 编辑: Ctrl+Shif ...

  6. 运输层协议----UDP

    import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import j ...

  7. UFLDL教程之(三)PCA and Whitening exercise

    Exercise:PCA and Whitening 第0步:数据准备 UFLDL下载的文件中,包含数据集IMAGES_RAW,它是一个512*512*10的矩阵,也就是10幅512*512的图像 ( ...

  8. Spring4.0整合Hibernate3 .6

    转载自:http://greatwqs.iteye.com/blog/1044271 6.5  Spring整合Hibernate 时至今日,可能极少有J2EE应用会直接以JDBC方式进行持久层访问. ...

  9. Hibernate中的一对多关系详解(2)

    一对多的关系:例如,部门对员工,一个部门可以有多个员工 多对一的关系:例如,员工对部门,多个员工属于一个部门,并且每个员工只能属于一个部门 那么一对多.多对一在数据库中的是怎样表示的呢?好多话都不说了 ...

  10. 去除UINavigationBar默认透明度的方法

    UINavigationbar的属性translucent,用来控制导航条的透明度的: iOS7+版本后,navigationbar的translucent属性默认为YES,及默认带有透明度 [sel ...