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 相关文章推荐
做好七件事帮你提升jQuery的性能
Feb 06 Javascript
JS在可编辑的div中的光标位置插入内容的方法
Nov 20 Javascript
javascript判断图片是否加载完成的方法推荐
May 13 Javascript
设置cookie指定时间失效(实例代码)
May 28 Javascript
Three.js利用Detector.js插件如何实现兼容性检测详解
Sep 26 Javascript
详解Webpack实战之构建 Electron 应用
Dec 25 Javascript
使用 Node.js 开发资讯爬虫流程
Jan 07 Javascript
vue组件 keep-alive 和 transition 使用详解
Oct 11 Javascript
你可能从未使用过的11+个JavaScript特性(小结)
Jan 08 Javascript
Vue父子传递实例讲解
Feb 14 Javascript
JavaScript类的继承多种实现方法
May 30 Javascript
基于Echarts图表在div动态切换时不显示的解决方式
Jul 20 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获取发送给用户的header信息的方法
2015/03/16 PHP
PHP is_array() 检测变量是否是数组的实现方法
2016/06/13 PHP
php封装的smarty类完整实例
2016/10/19 PHP
PHP与以太坊交互详解
2018/08/24 PHP
JavaScript入门教程(2) JS基础知识
2009/01/31 Javascript
jQuery.clean使用方法及思路分析
2013/01/07 Javascript
extjs 3.31 TreeGrid实现静态页面加载json到TreeGrid里面
2013/04/02 Javascript
javascript中apply和call方法的作用及区别说明
2014/02/14 Javascript
jQuery中slideUp()方法用法分析
2014/12/24 Javascript
浅谈Jquery为元素绑定事件
2015/04/27 Javascript
使用jquery实现仿百度自动补全特效
2015/07/23 Javascript
JS简单实现多级Select联动菜单效果代码
2015/09/06 Javascript
jQuery短信验证倒计时功能实现方法详解
2016/05/25 Javascript
javascript的document中的动态添加标签实现方法
2016/10/24 Javascript
JS实现的RGB网页颜色在线取色器完整实例
2016/12/21 Javascript
详解微信小程序调起键盘性能优化
2018/07/24 Javascript
函数式编程入门实践(一)
2019/04/20 Javascript
p5.js临摹旋转爱心
2019/10/23 Javascript
[03:04]DOTA2英雄基础教程 影魔
2013/12/11 DOTA
从零学Python之引用和类属性的初步理解
2014/05/15 Python
Python 读写文件的操作代码
2018/09/20 Python
python  创建一个保留重复值的列表的补码
2018/10/15 Python
python创建与遍历List二维列表的方法
2019/08/16 Python
史上最详细的Python打包成exe文件教程
2021/01/17 Python
CSS3动画:5种预载动画效果实例
2017/04/05 HTML / CSS
台湾网购生鲜第一品牌:i3Fresh爱上新鲜
2017/10/26 全球购物
如何让Java程序执行效率更高
2014/06/25 面试题
六一节目主持词
2014/04/01 职场文书
自动化专业毕业生求职信
2014/06/18 职场文书
课外活动总结范文
2014/07/09 职场文书
工作作风承诺书
2014/08/30 职场文书
交警作风整顿剖析材料
2014/10/11 职场文书
社会实践单位意见
2015/06/05 职场文书
ConstraintValidator类如何实现自定义注解校验前端传参
2021/06/18 Java/Android
python 字典和列表嵌套用法详解
2021/06/29 Python
MySQL笔记 —SQL运算符
2022/01/18 MySQL