js基础知识:表达式

一、什么是表达式?

我理解的“表达式”:程序执行到1个“表达式”时,会返回1个值到这个“表达式”所在的位置。

var a = 10 , b = 20;  // 这是初始化变量

console.log(a+b); // 计算变量a、b的值(标识符解析),然后返回两者的值到其所在位置。那么就相当于console.log(10+20)

二、常见的几种表达式

(一)原始表达式

1.直接量(字面量)

123 // 数字
‘hola‘ // 字符串

2.JavaScript的保留字

“保留字”就是在程序中有特殊意义的标识符,程序员不能使用它们作为变量了。

true; // 布尔值
this; // 函数的调用上下文

3.变量

var a = 10; alert(a); // 计算变量a的值,返回1个10,然后将10传入alert函数。

(二)数组表达式、对象表达式

数组表达式就是1个新创建的数组。

[1,2,3,4]; // 创建1个数组。

和数组表达式一样,对象表达式就是新建1个对象。

{x:1, y:2}; // 创建1个对象

(三)函数表达式

创建1个函数,可以采用函数声明的方式,也可以采用函数表达式的方式。函数表达式就是创建1个函数,将它的引用保存在1个变量中。

var foo = function(a){ return ‘传进来的实参是:‘ + a; }; // 创建1个匿名的函数,它的引用保存在变量foo中。

(四)属性访问表达式

属性访问表达式有2种语法:

1.“表达式.标示符”: “表达式”需要是1个对象,而“标示符”必须是对象已经存在的属性

var obj = {x:1, y:2}; console.log(obj.x); // obj.x返回obj对象中的x属性,1。

2.“表达式[表达式]”:第1个“表达式”同样需要是1个对象,而第2个“表达式”的值可以为:

(1)字符串:那么这就是对象的属性访问or属性设置。

对象的属性访问:

var obj = {x:1, y:2};  console.log(obj[‘x‘]); // 访问obj对象中x属性的值,返回1。

对象的属性设置(给1个属性赋值):

var obj = {x:1, y:2}; obj[‘z‘] = 3; console.log(obj); // { x=1,  y=2,  z=3}

(2)数字:数组元素访问。

var arr = [1,2,3,4]; console.log(arr[0]); // 访问数组中索引为0的元素,返回1。

(五)函数调用表达式

函数调用表达式就是这样的:“函数名(实参)”。函数调用表达式的返回值,取决于return语句。

1没写return语句:函数调用返回undefined。

    function add(x){
            x+x;
    }
    console.log( add(1) ); // 函数没有return语句,函数调用返回undefined。

2.写了return语句,但没写返回值:函数调用返回undefined。

    function add(x){
            x+x;
            return;
    }
    console.log( add(1) ); // 写了return语句但没有返回值,函数调用返回undefined。

3.写了return语句和要返回的表达式:返回表达式的值。

    function add(x){
        return x+x;
    }
    console.log( add(1) ); // 写了return语句,指定了返回值(x+x),所以函数调用返回2。

参考资料:

《JavaScript权威指南》(第6版) 4.1-4.6

时间: 2024-10-14 20:25:56

js基础知识:表达式的相关文章

JS基础知识回顾:ECMAScript的语法(一)

任何语言的核心都必然会描述这门语言最基本的工作原理,而描述的内容通常都要涉及这门语言的语法.操作符.数据类型.内置功能等用于构建复杂解决方案的基本概念. ECMAScript中的一切变量.函数名.操作符都区分大小写. ECMAScript的标识符要符合下列规则:第一个字符必须是字母.下划线或美元符号:其他字符可以是字母.下划线.美元符号或数字. 标识符中的字母也可以包含扩展的ASCII或Unicode字母字符,但是并不推荐. 按照惯例,ECMAScript标识符采用驼峰大小写的格式来书写,尽管没

JS基础知识回顾:引用类型(四)

每个函数都是Function类型的实例,而且都与其他引用类型一样具有属性和方法. 由于函数是对象,因此函数名实际上也是一个指向函数对象的指针,不会与某个函数绑定. 函数的声明有以下三种形式: function sum(num1,num2){return num1+num2;}//利用函数声明语法定义 var sum=function(num1,num2){return num1+num2;}//利用函数表达式定义 var sum=new Function("num1","nu

JS基础知识回顾:ECMAScript的语法(三)

ECMA-262描述了一组用于操作数据值的操作符,包括算术操作符.位操作符.关系操作符和相等操作符. ECMAScript操作符的与众不同之处在于,他们能够适用于很多值,例如字符串.数字值.布尔值.甚至是对象. 在将这些操作符应用于对象时,相应的操作符通常都会调用对象的valueOf()和(或)toString()方法,以便取得可以操作的值. 只能操作一个值的操作符叫做一元操作符. 递增和递减操作符直接借鉴自C,各有前置型和后置型两个版本:a++.++a.a--.--a 这四种操作符不仅适用于整

JS基础知识回顾:引用类型(三)

ECMAScript通过RegExp类型来支持正则表达式. 使用类似Perl的语法就可以创建一个正则表达式:var expression=/pattern/flags; 其中模式(pattern)部分可以是任何简单或复杂的正则表达式,可以包含字符类.限定符.分组.向前查找以及反向引用. 每个正则表达式都可以带有一个或多个标志(flags),用以标注正则表达式的行为. 正则表达式的匹配模式只是下列三个标志: g:表示全局(global)模式,即模式将被应用于所有字符串,而非在发现第一个匹配项时立即

JS基础知识大全

JS基础知识 基本语法*switch循环(设置表达式 x(通常是一个变量) 随后表达式的值会与结构中的每个 case 的值做比较.如果存在匹配,则与该 case 关联的代码块会被执行.请使用 break 来阻止代码自动地向下一个 case 运行) 不进行类型转换 var x; switch(x){ case true:console.log("x类型转换") ; default:console.log("x没有发生类型转换"); }//case没有发生类型转换 sw

JS基础知识回顾:引用类型(一)

在ECMAScript中引用类型是一种数据结构,用于将数据和功能组织在一起,而对象时引用类型的一个实例. 尽管ECMAScript从技术上讲是一门面向对象的语言,但它不具备传统的面向对象语言所支持的类和接口等基本结构,所以虽然说引用类型与类看起来想死,但他们并不是相同的概念. 不过引用类型有的时候也可以被称为对象定义,因为他们描述的是一类对象所具有的属性和方法. 新对象是使用new操作符后跟一个构造函数来实现的,构造函数本身就是一个函数,只不过该函数时处于创建新对象的目的而定义的. ECMASc

NodeJs>------->>第三章:Node.js基础知识

第三章:Node.js基础知识 一:Node.js中的控制台 1:console.log.console.info  方法 1 console.log("this is a test string."); 1 node app1.js 1> info.log 1 console.log("This is a test String ."); 2 3 //从第二个参数开始,依序输出所有的字符串 4 console.log("%s","

JS 基础知识4 运算符

JS的运算符一般含有: 1 算术运算符 2 相等运算符 3 关系运算符 4 字符串运算符 5逻辑运算符 6位运算符 7 赋值运算符 首先看算术运算符,它一般有(+,-,*,/,%,++,--) 这里,%模运算符,其实也就是取余的意思,比如,5%2=1: 这里要特别说一下++,与--(这里只列了++,--是一样的道理). 1 var i = 1; 2 var j = ++i; //实际相当于 i+=1;j=i; 3 alert(i + " " + j); 4 5 var m = 1; 6

JS 基础知识2 传值和传址

要知道传址跟传址,首先我们先了解下数据值的操作. 1复制:可以把它赋值给一个新的变量 2传递:可以将他传递给一个函数或者方法 3比较:可以与另外一个值比较,判断是否相等 简要介绍下传值: 当一个数据是通过值被操作的,那么关系到的是数据的值,在赋值的过程中,是对实际值进行了COPY,储存在一个变量或者属性或数组中,copy的值与原数据是相互独立的. 当数据通过值传递给一个函数时,数据的一份传递给这个函数,如果函数体修改了这个值,只在函数体受影响,函数外的原数据不受影响. 当一个数据通过值和另外一个

JS 基础知识3 变量

变量和数值相关,它储存了那个值,有了变量就可以储存操作数据了. js与其他语言不同,它是非类型的.就是变量可以存放任何类型的值,而其他语言需要存放特定类型的值. var i=5; i="fdsfad"; 这是合法的. 变量的声明一般是由VAR 关键字声明的 var i,sum; //一次声明两个变量,   若变量没有给定初始值,则值为“undefined” 在JS中多次声明同一个变量,是不会出错的,仅仅是给变量赋值的性质. 还有一种,不用var关键字声明变量,则JS会隐式的声明该变量,