JavaScript基础语法之js表达式


Posted in Javascript onJune 07, 2016

本文将详细介绍javascript表达式,表达式分为原始表达式和复杂表达式。一般,关于javascript基础语法,人们听得比较多的术语是操作符和语句。但,其实还有一个术语经常使用,却很少被提到,这就是javascript表达式(expression)。

原始表达式(primary exression)

原始表达式是表达式的最小单位——它不再包含其他表达式。javascript中的原始表达式包括this关键字、标识符引用、字面量引用、数组初始化、对象初始化和分组表达式

PrimaryExpression : 
this 
Identifier 
Literal 
ArrayLiteral 
ObjectLiteral 
( Expression )

this关键字和标识符

this;//返回当前对象

i;//返回变量i的值

sum;//返回变量sum的值

字面量

字面量(literal),又翻译成直接量,就是程序中直接使用的数据值

Literal ::
NullLiteral
BooleanLiteral
NumericLiteral
StringLiteral 
RegularExpressionLiteral 
null;
undefined;
true;
false;
1;
'abc';
/pattern/;

数组和对象初始化

数组初始化和对象初始化实际上是一个以字面量的方式描述的初始化的过程。这两个初始化表达式有时称做"对象直接量"和"数组直接量"

[];
[1,2,3];
{};
{a:1};

分组表达式

分组表达式实际上就是括号,用于重写运算符的优先级

复杂表达式(MemberExpression)

复杂表达式是由原始表达式和操作符(operator)组合而成,包括属性访问表达式、对象创建表达式和函数表达式

MemberExpression : 
MemberExpression [ Expression ] 
MemberExpression . IdentifierName 
new MemberExpression Arguments
FunctionExpression

属性访问表达式

属性访问表达式运算可以得到一个对象属性或一个数组元素的值,javascript为属性访问定义了两种语法

MemberExpression . IdentifierName 
MemberExpression [ Expression ]

第一种写法是一个表达式后跟随一个句点和标识符。表达式指定对象,标识符则指定需要访问的属性的名称

第二种写法是使用方括号,方括号内是另外一个表达式(这种方法适用于对象和数组)。第二个表达式指定要访问的属性的名称或代表要访问数组元素的索引

var o = {x:1,y:{z:3}}; //对象字面量
var a = [o,4,[5,6]]; // 包含对象的数组字面量
o.x;//表达式o的x属性
o.y.z;//表达式o.y的z属性
o['x'];//对象o的x属性
a[1];//表达式a中索引为1的元素

不管使用哪种形式的属性访问表达式,在'.'和'['之前的表达式总是会首先计算

如果计算结果是null或undefined,表达式会抛出一个类型错误异常,因为这两个值都不能包含任意属性

如果计算结果不是对象,javascript会将其转换为对象

如果对象表达式后跟随句点和标识符,则会查找由这个标识符指定的属性值,并将其作为整个表达式的值返回

如果对象表达式后跟随一对方括号,则会计算方括号内的表达式的值并将其转换为字符串

不论哪种情况,如果命名的属性不存在,那么整个属性访问表达式的值就是undefined

对象创建表达式

对象创建表达式创建一个对象并调用一个函数初始化新对象的属性

new Object();
new Point(2,3);

如果一个对象创建表达式不需要传入任何参数给构造函数的话,那么这对空圆括号是可以省略的

new Object;

函数表达式

函数表达式分为函数定义表达式和函数调用表达式

函数定义表达式定义一个javascript函数,表达式的值是这个新定义的函数

一个典型的函数定义表达式包含关键字function,跟随其后的是一对圆括号,括号内是一个以逗号分割的列表,列表含有0个或多个标识符(参数名),然后再跟随一个由花括号包裹的

javascript代码段(函数体)

function square(x){
return x*x;
}

函数定义表达式同样可以包含函数的名字,函数也可以通过函数语句来定义,而不是函数表达式

var square = function(x){return x*x;}

函数调用表达式是一种调用或执行函数或方法的语法表示。如果这个表达式是一个属性访问表达式,那么这个调用称做方法调用

f(0);
Math.max(x,y,z);
a.sort();

以上所述是小编给大家介绍的JavaScript基础语法之js表达式的相关内容,希望对大家有所帮助。如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jQuery实战之品牌展示列表效果
Apr 10 Javascript
THREE.JS入门教程(4)创建粒子系统
Jan 24 Javascript
javascript数组遍历for与for in区别详解
Dec 04 Javascript
JavaScript判断浏览器类型的方法
Feb 10 Javascript
详解JavaScript中数组的相关知识
Jul 29 Javascript
jquery实现页面虚拟键盘特效
Aug 08 Javascript
Bootstrap~多级导航(级联导航)的实现效果【附代码】
Mar 08 Javascript
Three.js快速入门教程
Sep 09 Javascript
jQuery验证表单格式的使用方法
Jan 10 Javascript
JS实现仿UC浏览器前进后退效果的实例代码
Jul 17 Javascript
详解如何解决vue开发请求数据跨域的问题(基于浏览器的配置解决)
Nov 12 Javascript
javascript移动端 电子书 翻页效果实现代码
Sep 07 Javascript
JavaScript必看小技巧(必看)
Jun 07 #Javascript
通过正则表达式获取url中参数的简单实现
Jun 07 #Javascript
点击按钮出现60秒倒计时的简单js代码(推荐)
Jun 07 #Javascript
javascript显示倒计时控制按钮的简单实现
Jun 07 #Javascript
基于jQuery下拉选择框插件支持单选多选功能代码
Jun 07 #Javascript
jQuery原理系列-css选择器的简单实现
Jun 07 #Javascript
javascript实现抽奖程序的简单实例
Jun 07 #Javascript
You might like
MySQL GBK→UTF-8编码转换
2007/05/24 PHP
关于Iframe如何跨域访问Cookie和Session的解决方法
2013/04/15 PHP
php 购物车完整实现代码
2014/06/05 PHP
php中file_get_content 和curl以及fopen 效率分析
2014/09/19 PHP
php使用cookie保存用户登录的用户名实例
2015/01/26 PHP
PHP实现大数(浮点数)取余的方法
2017/02/18 PHP
PHP插件PHPMailer发送邮件功能
2017/02/28 PHP
javascript引用对象的方法代码
2007/08/13 Javascript
利用jquery的获取JS文件中的字符串内容
2012/02/14 Javascript
js在IE与firefox的差异集锦
2014/11/11 Javascript
浅析jQuery 3.0中的Data
2016/06/14 Javascript
Bootstrap栅格系统的使用和理解2
2016/12/14 Javascript
微信小程序 页面跳转及数据传递详解
2017/03/14 Javascript
p5.js入门教程之键盘交互
2018/03/19 Javascript
微信小程序页面传多个参数跳转页面的实现方法
2019/05/17 Javascript
Vue+Typescript中在Vue上挂载axios使用时报错问题
2019/08/07 Javascript
vue 组件销毁并重置的实现
2020/01/13 Javascript
vue实现简单图片上传
2020/06/30 Javascript
Python去除列表中重复元素的方法
2015/03/20 Python
低版本中Python除法运算小技巧
2015/04/05 Python
Python实现对excel文件列表值进行统计的方法
2015/07/25 Python
Python实现八大排序算法
2016/08/13 Python
python搭建虚拟环境的步骤详解
2016/09/27 Python
python 系统调用的实例详解
2017/07/11 Python
django 将model转换为字典的方法示例
2018/10/16 Python
详解pandas库pd.read_excel操作读取excel文件参数整理与实例
2019/02/17 Python
Python3.7下安装pyqt5的方法步骤(图文)
2020/05/12 Python
CSS3的column-fill属性对齐列内容高度的用法详解
2016/07/01 HTML / CSS
家得宝加拿大家装网上商店:The Home Depot加拿大
2016/08/27 全球购物
职业生涯规划书结束语
2014/04/15 职场文书
上课随便讲话检讨书
2014/09/12 职场文书
公司行政助理岗位职责
2015/04/11 职场文书
2015年学校精神文明工作总结
2015/05/27 职场文书
河童之夏观后感
2015/06/11 职场文书
音乐研修感悟
2015/11/18 职场文书
小学记事作文之200字
2019/08/06 职场文书