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
js基础知识:表达式的更多相关文章
- JS基础知识笔记
2020-04-15 JS基础知识笔记 // new Boolean()传入的值与if判断一样 var test=new Boolean(); console.log(test); // false ...
- [JS复习] JS 基础知识
项目结尾,空闲时间,又把<JS 基础知识> 这本书过了一遍,温故知新后,很多知其然不知其所以然的内容 豁然开朗. [1. 用于范围的标签] display :inline or bloc ...
- HTML+CSS+JS基础知识
HTML+CSS+JS基础知识 目录 对HTML+CSS+JS的理解 基础知识 对HTML+CSS+JS的理解 基础知识 插入样式表的三种方式 外部样式表:<link rel="sty ...
- Node.js基础知识
Node.js入门 Node.js Node.js是一套用来编写高性能网络服务器的JavaScript工具包,一系列的变化由此开始.比较独特的是,Node.js会假设在POSIX环境下运行 ...
- 网站开发进阶(十五)JS基础知识充电站
JS基础知识充电站 1.javascript alert弹出对话框时确定和取消两个按钮返回值? 用的不是alert对话框,是confirm confirm(str); 参数str:你要说的话或问题: ...
- NodeJs>------->>第三章:Node.js基础知识
第三章:Node.js基础知识 一:Node.js中的控制台 1:console.log.console.info 方法 console.log(" node app1.js 1> ...
- js基础知识温习:Javascript中如何模拟私有方法
本文涉及的主题虽然很基础,在很多人眼里属于小伎俩,但在JavaScript基础知识中属于一个综合性的话题.这里会涉及到对象属性的封装.原型.构造函数.闭包以及立即执行表达式等知识. 公有方法 公有方法 ...
- js基础知识--BOM
之前说过,在js的 运行环境为浏览器时,js就主要有三部分组成: ECMAScript核心语法.BOM.DOM.今天就和大家详细说一下BOM的一些基础知识. BOM BOM通常被称为浏览器对象模型,主 ...
- JS基础知识总结
js基础知识点总结 如何在一个网站或者一个页面,去书写你的js代码:1.js的分层(功能):jquery(tool) 组件(ui) 应用(app),mvc(backboneJs)2.js的规划() ...
- js基础知识总结(2016.11.1)
js基础知识点总结 如何在一个网站或者一个页面,去书写你的js代码:1.js的分层(功能):jquery(tool) 组件(ui) 应用(app),mvc(backboneJs)2.js的规划():避 ...
随机推荐
- Appium移动自动化测试之Eclipse
下载eclipse,这个下载方式比较多,eclipse官网,CSDN都有的下,版本根据自己操作系统选择,切记eclipse版本一定要与JDK版本一至,不然eclipse无法启动.现在我们来搭建Andr ...
- GOOGLE地图坐标拾取方法、GOOGLE地图获取坐标方法
方法一: 打开google地图-->查找目的地-->右键:此位置居中--> 打开IE浏览器(百度浏览器.GOOGLE浏览器.360浏览器均不行,只能在IE中获取),在IE浏览器的地址 ...
- linux 下进程通讯详解
linux 下进程通讯方法主要有以下六种: 1.管道 2.信号 3.共享内存 4.消息队列 5.信号量 6.socket
- 未添加document.ready产生的BUG
今天在框架里使用superslide插件时,在javascript部分 <script type="text/javascript"> jQuery(".yj ...
- SQL 存储过程优化经验
经现场同事反映,他们用的好好的XML 导出工具最近一直报错,经常报数据库连接超时,查看数据库发现已经有100G 以上有空间了. 但导出数据的存储过程里面每次按时间只导1000多条数据,近理说有时间过滤 ...
- iOS10字体
iOS10字体随着手机系统的字体改变,当我们手机系统字体改变以后,我们的app的lable也会跟着一起变化: 同样的6sp,在iOS9上面运行字体显示是没问题的,当我的手机更新了iOS10以后,有的界 ...
- NashZhou的自我介绍
行业: 电子商务服务业,目前主要是淘宝开放平台,ISV 关键词: 电商,淘宝直通车,关键词广告,自动优化 当前目标: 广告算法 广告主自动优化 希望能在这里结识有共同爱好踏实上进的园友,共同学习,共同 ...
- 如何查看apache,php,mysql的编译参数
查看nginx编译参数:/usr/local/nginx/sbin/nginx -V 查看apache编译参数:cat /usr/local/apache2/build/config.nice 查看m ...
- xcode8 上传ipa文件无法构建版本
在xcode8 升级后上传ipa文件 需要设置一个安全提示,现在上传app store的方式为xcode或者 application loader 一.xcode 准备工作完成后点击Product-- ...
- HMC V7.9.0升级至SP2版本
补丁下载地址:http://www-933.ibm.com/support/fixcentral/ 选择补丁版本 MH01405是和ftp://ftp.software.ibm.com/softwar ...