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 相关文章推荐
javascript之可拖动的iframe效果代码
Aug 01 Javascript
(jQuery,mootools,dojo)使用适合自己的编程别名命名
Sep 14 Javascript
jquery 提交值不为空的元素示例代码
May 10 Javascript
javaScript如何生成xmlhttp
Dec 16 Javascript
javascript实现浏览器窗口传递参数的方法
Sep 03 Javascript
node.js中的buffer.Buffer.byteLength方法使用说明
Dec 10 Javascript
jquery图形密码实现方法
Mar 11 Javascript
jQuery.Highcharts.js绘制柱状图饼状图曲线图
Mar 14 Javascript
AngularJS入门教程之迭代器过滤详解
Aug 18 Javascript
iframe高度自适应及隐藏滚动条的实例详解
Sep 29 Javascript
微信小程序实现红包雨功能
Jul 11 Javascript
antd design table更改某行数据的样式操作
Oct 31 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
神族 PROTOSS 概述
2020/03/14 星际争霸
php5.3中连接sqlserver2000的两种方法(com与ODBC)
2012/12/29 PHP
php中的常用魔术方法总结
2013/08/02 PHP
简单了解将WordPress中的工具栏移到底部的小技巧
2015/12/31 PHP
ECMAScript 基础知识
2007/06/29 Javascript
JavaScript中的几个关键概念的理解-原型链的构建
2011/05/12 Javascript
JavaScript高级程序设计 阅读笔记(十七) js事件
2012/08/14 Javascript
js汉字转拼音实现代码
2013/02/06 Javascript
JavaScript加强之自定义callback示例
2013/09/21 Javascript
MyEclipse取消验证Js的两种方法
2013/11/14 Javascript
javascript中parentNode,childNodes,children的应用详解
2013/12/17 Javascript
Javascript中arguments对象详解
2014/10/22 Javascript
jQuery实现的Div窗口震动效果实例
2015/08/07 Javascript
基于JavaScript代码实现随机漂浮图片广告
2016/01/05 Javascript
AngularJS内建服务$location及其功能详解
2016/07/01 Javascript
用jquery获取自定义的标签属性的值简单实例
2016/09/17 Javascript
JS中正则表达式要注意lastIndex属性
2017/08/08 Javascript
vue 虚拟dom的patch源码分析
2018/03/01 Javascript
ES6学习笔记之字符串、数组、对象、函数新增知识点实例分析
2020/01/22 Javascript
vue addRoutes路由动态加载操作
2020/08/04 Javascript
Python简单遍历字典及删除元素的方法
2016/09/18 Python
利用python求解物理学中的双弹簧质能系统详解
2017/09/29 Python
python实现连续图文识别
2018/12/18 Python
实时获取Python的print输出流方法
2019/01/07 Python
Django利用cookie保存用户登录信息的简单实现方法
2019/05/27 Python
python使用Word2Vec进行情感分析解析
2020/07/31 Python
Django restful framework生成API文档过程详解
2020/11/12 Python
网页布局中CSS样式无效的十个重要原因详解
2017/08/10 HTML / CSS
美国牛仔品牌:True Religion
2018/11/16 全球购物
文员岗位职责范本
2014/03/08 职场文书
煤矿开采专业求职信
2014/07/08 职场文书
交通事故委托书范本(2篇)
2014/09/21 职场文书
2016年大学生暑期社会实践方案
2015/11/26 职场文书
nginx 防盗链防爬虫配置详解
2021/03/31 Servers
详解vue身份认证管理和租户管理
2021/05/25 Vue.js
Python之matplotlib绘制折线图
2022/04/13 Python