前面的话

  如果表达式在javascript中是短语,那么语句(statement)就是javascript整句或命令。表达式计算出一个值,语句用来执行以使某件事发生。javascript程序无非就是一系列可执行语句的集合,javascript解释器依照语句的编写顺序依次执行。本文将介绍javascript语句中的四类语句——表达式语句、块语句、空语句和声明语句

表达式语句

  表达式语句(expression statement)是javascript中最简单的语句,赋值、delete、函数调用这三类即是表达式,又是语句,所以叫做表达式语句

//赋值语句
greeting = 'hello ' + name;
i* = 3; //递增运算符(++)和递减运算符(--)和赋值语句有关,它们的作用是改变一个变量的值,就像执行一条赋值语句一样
counter++; //delete运算符
delete o.x; //函数调用
alert(greeting);
window.close();
cs = Math.cos(x);

  javascript语句以分号结束,但表达式不需要分号结尾。一旦在表达式后面添加分号,则javascript引擎就将表达式视为语句,这样会产生一些没有任何意义的语句(表达式语句除外)

1 + 3;
'abc';

块语句

  块语句又叫复合语句,javascript将多条语句联合在一起,形成一条复合语句(compound statement)

  复合语句只须用花括号将多条语句括起来即可

{
x = Math.PI;
cx = Math.cos(x);
console.log(cx);
}

  关于块语句,有以下几点注意事项:

  【1】语句块的结尾不需要分号。块中的原始语句必须以分号结束,但语句块不需要

  【2】语句块中的行都有缩进,这不是必须的,但整齐的缩进能让代码可读性更强,更容易理解

  【3】javascript中没有块级作用域,在语句块中声明的变量并不是语句块私有的(不包括es6)

{
var i = 0;
console.log(i++);//
}
console.log(i++);//

空语句

  在javascript中,当希望多条语句被当做一条语句使用时,使用复合语句来替代。空语句(empty statement)则恰好相反,它允许包含0条语句

;

  javascript解释器执行空语句时不会执行任何动作。但当创建一个具有空循环体的循环时,空语句是有用的

  在下面这个循环中,所有的操作都在表达式a[i++]=0中完成,这里并不需要任何循环体。然而javascript需要循环体中至少包含一条语句,因此,这里只使用了一个单独的分号来表示一条空语句

//初始化一个数组a
for(i = 0; i < a.length; a[i++] = 0);

  在for、while循环或if语句的右圆括号后的分号很不起眼,这可能造成一些bug,而这些bug很难定位到

//因为;的多余,造成与预想不同的结果
if((a == 0) || (b == 0));
o = null;

  如果有特殊目的需要使用空语句,最好在代码中添加注释,这样可以更清楚地说明这条空语句是有用的

for(i = 0; i < a.length; a[i++] = 0)/*empty*/;

声明语句

  声明语句包括变量声明和函数声明,分别使用var和function关键字

  var语句用来声明一个或者多个变量,关键字var之后跟随的是要声明的变量列表,列表中的每一个变量都可以带有初始化表达式,用于指定它的初始值

var name_1 [ = value_1] [,...,name_n[=value_n]]
var i ;
var j = 0;
var p,q;
var x = 2, y = r;

  关键字function用来定义函数,funcname是要声明的函数的名称的标识符,函数名之后的圆括号中是参数列表,参数之间使用逗号分隔。当调用函数时,这些标识符则指代传入函数的实参

  函数体是由javascript语句组成的,语句的数量不限,且用花括号括起来。在定义函数时,并不执行函数体内的语句,它和调用函数时待执行的新函数对象相关联

function funcname([arg1 [,arg2 [...,argn]]]){statement}

  function语句里的花括号是必需的,这和while循环和其他一些语句所使用的语句块是不同的,即使函数体内只包含一条语句,仍然必须使用花括号将其括起来

//正确
function hypotenuse(x,y){
return Math.sqrt(x*x + y*y);
}
//错误
function hypotenuse(x,y)
return Math.sqrt(x*x + y*y);

  函数声明语句和函数定义表达式包含相同的函数名,但二者有所不同

//表达式
var f = function(x){return x+1;}
//语句
function f(x){return x+1;}

  函数定义表达式只有变量声明提前了,变量的初始化代码仍然在原来的位置;而函数声明语句的函数名称和函数体均提前,脚本中的所有函数和函数中所有嵌套的函数都会在当前上下文中其他代码之前声明,也就是说,可以在声明一个javascript函数之前调用它

console.log(f1(0));//Uncaught TypeError: f1 is not a function
var f1 = function(x){return x+1;} console.log(f2(0));//
function f2(x){return x+1;}

  变量声明语句和函数声明语句有几点相似之处

  【1】变量声明语句和函数声明语句都会提前

console.log(a);//undefined
var a = 0;
console.log(a);// console.log(f(0));//
function f(x){return x+1;}
console.log(f(0));//

  【2】变量声明语句和函数声明语句创建的变量都无法删除

var a = 0;
delete a;
console.log(a);//0 function f(x){return x+1;}
delete f;
console.log(f(0));//

参考资料

【1】 ES5/语句 https://www.w3.org/html/ig/zh/wiki/ES5/statements
【2】 阮一峰Javascript标准参考教程——语法概述 http://javascript.ruanyifeng.com/grammar/basic.html#toc12
【3】《javascript权威指南(第6版)》第5章 语句

javascript语句——表达式语句、块语句、空语句和声明语句的更多相关文章

  1. Javascript中表达式和语句的区别

    一.表达式:一个表达式会产生一个值,它可以放在任何需要一个值的地方,比如,作为一个函数调用的参数. 以下例子就是表达式: a=35: b=1+a; a=function (){return 6}: b ...

  2. 嵌入式C语言自我修养 03:宏构造利器:语句表达式

    3.1 基础复习:表达式.语句和代码块 表达式 表达式和语句是 C 语言中的基础概念.什么是表达式呢?表达式就是由一系列操作符和操作数构成的式子.操作符可以是 C 语言标准规定的各种算术运算符.逻辑运 ...

  3. Linux高级之语句表达式

    表达式 表达式和语句是 C 语言中的基础概念.什么是表达式呢?表达式就是由一系列操作符和操作数构成的式子.操作符可以是 C 语言标准规定的各种算术运算符.逻辑运算符.赋值运算符.比较运算符等.操作数可 ...

  4. JavaScript中:表达式和语句的区别

    JavaScript中:表达式和语句的区别 Javascript语言精粹:表达式是由运算符构成,并运算产生结果的语法结构.程序是由语句构成,语句则是由“:(分号)”分隔的句子或命令.如果在表达式后面加 ...

  5. JavaScript 中表达式和语句的区别

    1.语句和表达式 JavaScript中的表达式和语句是有区别的.一个表达式会产生一个值,它可以放在任何需要一个值的地方,比如,作为一个函数调用的参数.下面的每行代码都是一个表达式: myvar3 + ...

  6. 【C# 基础概念】表达式(expression)、语句(statement)、块(block),指令(using)

    官方链接:https://docs.microsoft.com/zh-cn/dotnet/csharp/programming-guide/statements-expressions-operato ...

  7. java基础-表达式,语句和代码块

    浏览以下内容前,请点击并阅读 声明 表达式 表达式由变量,操作符和方法调用组成,表达式的返回值类型由表达式中的元素(如操作符,变量等)决定如: cadence = 0 上述代码将返回一个int类型的值 ...

  8. Java代码三级跳——表达式、语句和代码块

    Java代码三级跳—表达式.语句和代码块 表达式(expression):Java中最基本的一个运算.比如一个加法运算表达式.1+2是一个表达式,a+b也是. 语句(statement):类似于平时说 ...

  9. js之语句(表达式语句,复合语句,声明语句)

    语句就是JavaScript整句或命令,以分号结束,用来执行以使某件事发生.下面将介绍三种语句:表达式语句,复合语句,声明语句. 一.表达式语句 表达式语句是javascript中最简单的语句 < ...

随机推荐

  1. LIS最长上升子序列O(n^2)与O(nlogn)的算法

    动态规划 最长上升子序列问题(LIS).给定n个整数,按从左到右的顺序选出尽量多的整数,组成一个上升子序列(子序列可以理解为:删除0个或多个数,其他数的顺序不变).例如序列1, 6, 2, 3, 7, ...

  2. ubuntu下面mysql,通过载入txt文件初始化数据表

    环境:ubuntu12.04   mysql(通过apt安装) (1)根据数据表中的属性列,对应在txt中构造记录(一行对应一条记录),不同属性之间通过tab键(以/root目录下构建的init.tx ...

  3. [转] spring @Entity @Table

    实体bean,entity 注解设置 持久化是位于JDBC之上的一个更高层抽象.持久层将对象映射到数据库,以便在查询.装载.更新或删除对象的时候,无须使用像JDBC那样繁琐的API.EJB的早期版本中 ...

  4. jsti 和EL用法注意点

    今天使用stl 结合El做jsp页面展现,出现了个问题,怎么调也调不好,最后将jstl的源码拿来跟踪调了一下才明白其中的道理. 在使用jstl tag <c:forEach var=" ...

  5. velocity整合servlet

    目录结构点我下载工程代码俩实体类不用说了看CustomerVelocityServlet类 package com.velocity.servlet;import java.util.ArrayLis ...

  6. Eclipse无法启动错误之Ensure that the org.eclipse.core.runtime bundle is resolved and started (see config.ini)

    悲剧,在安装Android Build Tools时,提醒需要关闭Eclipse进行安装,于是我在Tools安装完成后重启了Eclipse.但是Eclipse却无法启动,在log中有如下提示: Una ...

  7. nginx.conf配置(支持thinkphp)

    error_log /home/wwwlogs/nginx_error.log crit; pid /usr/local/nginx/logs/nginx.pid; #Specifies the va ...

  8. 灰色预测原理及JAVA实现

    最近在做项目时,用户不想使用平均值来判断当前数据状态,想用其他的方式来分析数据的变化状态,在查找了一些资料后,想使用灰色预测来进行数据的预测.下面的内容是从网上综合下来的,java代码也做了一点改动, ...

  9. [转]单点登录SSO学习——CAS协议内容

    作者:anmaler 本文转自:http://blog.zhaojunling.me/p/24 CAS中文文档甚少,这篇文章对CAS接口参数有比较清楚的说明,排版也不错查阅舒适 在当前互联网产品中使用 ...

  10. 微软正式发布Visual Studio 2013 Update 3 (2013.3) RTM

    昨天微软的Visual Studio 2013 Update 3(Visual Studio 2013.3)正式发布(RTM)了,做为微软认证金牌合作的葡萄城控件,我们组织力量第一时间进行翻译.分享给 ...