JavaScript中字面量与函数的基本使用知识


Posted in Javascript onOctober 20, 2015

JavaScript 字面量
在编程语言中,一个字面量是一个常量,如 3.14。
数字(Number)字面量 可以是整数或者是小数,或者是科学计数(e)。

3.14

1001

123e5

字符串(String)字面量 可以使用单引号或双引号 be written with double or single quotes:

"John Doe"

'John Doe'

表达式字面量 用于计算:

5 + 6

5 * 10

数组(Array)字面量 定义一个数组:

[40, 100, 1, 5, 25, 10]

对象(Object)字面量 定义一个对象:

{firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"}

函数(Function)字面量 定义一个函数:

function myFunction(a, b) { return a * b;}

JavaScript 函数定义
JavaScript 使用关键字 function 定义函数。
函数可以通过声明定义,也可以是一个表达式。
函数声明
在之前的教程中,你已经了解了函数声明的语法 :

function functionName(parameters) {
 执行的代码
}

函数声明后不会立即执行,会在我们需要的时候调用到。
实例

function myFunction(a, b) {
  return a * b;
}

Note 分号是用来分隔可执行JavaScript语句。
由于函数声明不是一个可执行语句,所以不以分号结束。

函数表达式
JavaScript 函数可以通过一个表达式定义。
函数表达式可以存储在变量中:
实例

var x = function (a, b) {return a * b};

在函数表达式存储在变量后,变量也可作为一个函数使用:
实例

var x = function (a, b) {return a * b};
var z = x(4, 3);

以上函数实际上是一个 匿名函数 (函数没有名称)。
函数存储在变量中,不需要函数名称,通常通过变量名来调用。
Note 上述函数以分号结尾,因为它是一个执行语句。

Function() 构造函数
在以上实例中,我们了解到函数通过关键字 function 定义。
函数同样可以通过内置的 JavaScript 函数构造器(Function())定义。
实例

var myFunction = new Function("a", "b", "return a * b");

var x = myFunction(4, 3);

实际上,你不必使用构造函数。上面实例可以写成:
实例

var myFunction = function (a, b) {return a * b}

var x = myFunction(4, 3);

Note 在 JavaScript 中,很多时候,你需要避免使用 new 关键字。

函数提升(Hoisting)
在之前的教程中我们已经了解了 "hoisting(提升)"。
提升(Hoisting)是 JavaScript 默认将当前作用域提升到前面去的的行为。
提升(Hoisting)应用在变量的声明与函数的声明。
因此,函数可以在声明之前调用:

myFunction(5);

function myFunction(y) {
  return y * y;
}

使用表达式定义函数时无法提升。
自调用函数
函数表达式可以 "自调用"。
自调用表达式会自动调用。
如果表达式后面紧跟 () ,则会自动调用。
Y不能自调用声明的函数。
通过添加括号,来说明它是一个函数表达式:
实例

(function () {
  var x = "Hello!!";   // 我将调用自己
})();

以上函数实际上是一个 匿名自我调用的函数 (没有函数名)。
函数可作为一个值使用
JavaScript 函数作为一个值使用:
实例

function myFunction(a, b) {
  return a * b;
}

var x = myFunction(4, 3);

JavaScript 函数可作为表达式使用:
实例

function myFunction(a, b) {
  return a * b;
}

var x = myFunction(4, 3) * 2;

函数是对象
在 JavaScript 中使用 typeof 操作符判断函数类型将返回 "function" 。
但,JavaScript 函数描述为一个对象更加准确。
JavaScript 函数有 属性 和 方法。
arguments.length 属性返回函数调用过程接收到的参数个数:
实例

function myFunction(a, b) {
  return arguments.length;
}

toString() 方法将函数作为一个字符串返回:
实例

function myFunction(a, b) {
  return a * b;
}

var txt = myFunction.toString();

Javascript 相关文章推荐
脚本吧 - 幻宇工作室用到js,超强推荐expand.js
Dec 23 Javascript
一个无限级XML绑定跨框架菜单(For IE)
Jan 27 Javascript
JSQL 批量图片切换的实现代码
May 05 Javascript
JavaScript中匿名、命名函数的性能测试
Sep 04 Javascript
node.js中的fs.rmdirSync方法使用说明
Dec 16 Javascript
简介JavaScript中Math.cos()余弦方法的使用
Jun 15 Javascript
跟我学习javascript的作用域与作用域链
Nov 19 Javascript
vue两个组件间值的传递或修改方式
Jul 04 Javascript
ES6知识点整理之对象解构赋值应用示例
Apr 17 Javascript
JS面向对象编程基础篇(三) 继承操作实例详解
Mar 03 Javascript
extjs图表绘制之条形图实现方法分析
Mar 06 Javascript
VUE table表格动态添加一列数据,新增的这些数据不可以编辑(v-model绑定的数据不能实时更新)
Apr 03 Javascript
JavaScript基本的输出和嵌入式写法教程
Oct 20 #Javascript
javascript省市级联功能实现方法实例详解
Oct 20 #Javascript
基于JavaScript实现移动端TAB触屏切换效果
Oct 20 #Javascript
js点击文本框后才加载验证码实例代码
Oct 20 #Javascript
javascript实现状态栏中文字动态显示的方法
Oct 20 #Javascript
基于jQuery实现的扇形定时器附源码下载
Oct 20 #Javascript
JS实现仿Windows经典风格的选项卡Tab切换代码
Oct 20 #Javascript
You might like
php将gd生成的图片缓存到memcache的小例子
2013/06/05 PHP
WordPress中用于获取文章作者与分类信息的方法整理
2015/12/17 PHP
WordPress中编写自定义存储字段的相关PHP函数解析
2015/12/25 PHP
基于jQuery实现的Ajax 验证用户名是否存在的实现代码
2011/04/06 Javascript
js中同步与异步处理的方法和区别总结
2013/12/25 Javascript
通过实例理解javascript中没有函数重载的概念
2015/06/03 Javascript
基于JQuery实现图片轮播效果(焦点图)
2016/02/02 Javascript
Extjs4.0 ComboBox如何实现三级联动
2016/05/11 Javascript
JavaScript原生数组Array常用方法
2017/04/06 Javascript
vue input 输入校验字母数字组合且长度小于30的实现代码
2018/05/16 Javascript
微信小程序页面缩放式侧滑效果的实现代码
2018/11/15 Javascript
JS实现求5的阶乘示例
2019/01/21 Javascript
ES6小技巧之代替lodash
2019/06/07 Javascript
js实现小时钟效果
2020/03/25 Javascript
[05:39]2014DOTA2国际邀请赛 DK晋级胜者组专访战队国士无双
2014/07/14 DOTA
[56:46]Liquid vs IG 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
利用Python如何生成便签图片详解
2018/07/09 Python
python用for循环求和的方法总结
2019/07/08 Python
Python 操作mysql数据库查询之fetchone(), fetchmany(), fetchall()用法示例
2019/10/17 Python
python读取mysql数据绘制条形图
2020/03/25 Python
Jupyter notebook 启动闪退问题的解决
2020/04/13 Python
python多进程 主进程和子进程间共享和不共享全局变量实例
2020/04/25 Python
Python3开发环境搭建详细教程
2020/06/18 Python
python和JavaScript哪个容易上手
2020/06/23 Python
Python dict的常用方法示例代码
2020/06/23 Python
python文件操作seek()偏移量,读取指正到指定位置操作
2020/07/05 Python
美特斯邦威官方商城:邦购网
2016/10/13 全球购物
《藤野先生》教学反思
2014/02/19 职场文书
2014年党务公开实施方案
2014/02/27 职场文书
保护环境标语
2014/06/09 职场文书
法人代表授权委托书范文
2014/09/10 职场文书
学校办公室主任岗位职责
2015/04/01 职场文书
2015年安全员工作总结范文
2015/04/22 职场文书
2015暑期工社会实践报告
2015/07/13 职场文书
干货:我将这样书写我的演讲稿!
2019/05/09 职场文书
JS新手入门数组处理的实用方法汇总
2021/04/07 Javascript