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. 可扩展多线程异步Socket服务器框架EMTASS 2.0 续

    转载自Csdn:http://blog.csdn.net/hulihui/article/details/3158613 (原创文章,转载请注明来源:http://blog.csdn.net/huli ...

  2. .NET 操作PDF文档以及PDF文件打印摸索总结

    关于生成 PDF 的操作,相信大家的在实际的工作过程中难免会碰到.以前我们通过生成 word 文档来进行文件的打印,但是由于太过依赖 office 软件,因此尝试能不能使用 PDF 进行文件打印. 在 ...

  3. js基础知识之_函数

    javascript函数 函数概念 将完成某一特定功能的代码集合起来,可以重复使用 白话函数理解-函数就是一个工厂,帮大家实现某一个功能 优点 -时程序更加简洁 -逻辑更有条例 -调用方便 -维护更加 ...

  4. AngularJS code converage

    karma-coverage The easiest way is to keep karma-coverage as a devDependency in your package.json. Mo ...

  5. iterator迭代器的使用

    部分摘自C++ Primer: 所有的标准库容器类都定义了相应的iterator类型,如vector:vector<int>::iterator iter; 这条语句定义了一个名为iter ...

  6. ACM YTU 十进制与八进制的转换 (栈和队列) STL栈调用

    十进制与八进制的转换(栈和队列) Description 对于输入的任意一个非负十进制整数,利用栈打印输出与其等值的八进制数. Input 111 Output 157 Sample Input 14 ...

  7. [转] js call

    call 方法  转自: http://www.cnblogs.com/sweting/archive/2009/12/21/1629204.html调用一个对象的一个方法,以另一个对象替换当前对象. ...

  8. PreResultListener使用

    PreResultListener是一个监听器接口,可以在Action处理完之后,系统转入实际视图前被回调. Struts2应用可以给Action.拦截器添加PreResultListener监听器, ...

  9. Ubuntu14.04不支持U盘exfat格式该如何解决

    转: http://www.jb51.net/os/Ubuntu/275158.html exfat是U盘的文件系统,很多系统都支持exfat格式的使用,但Ubuntu系统并不支持exfat格式,要如 ...

  10. [译]36 Days of Web Testing(五)

    Day 23 禁用CSS  Disable CSS 为什么 ? CSS,层叠样式表,是用来定义web页面布局和显示的机制.通过修改CSS样式,可以改变整个页面的外观. 但是有一些人,因为之前的选择或者 ...