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 分页控件实现代码
Nov 30 Javascript
通过jquery的$.getJSON做一个跨域ajax请求试验
May 03 Javascript
让table变成exls的示例代码
Mar 24 Javascript
jQuery实现视频作为全屏幕背景
Dec 18 Javascript
jQuery实现Flash效果上下翻动的中英文导航菜单代码
Sep 22 Javascript
JavaScrip调试技巧之断点调试
Oct 22 Javascript
基于JS实现省市联动效果代码分享
Jun 06 Javascript
动态JavaScript所造成一些你不知道的危害
Sep 25 Javascript
jquery css实现邮箱自动补全
Nov 14 Javascript
JS实现点击按钮可实现编辑功能
Jul 03 Javascript
vue兄弟组件传递数据的实例
Sep 06 Javascript
JS JQuery获取data-*属性值方法解析
Sep 01 jQuery
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
DC动画电影《黑暗正义联盟》曝预告 5月5日上线数字平台
2020/04/09 欧美动漫
mysql desc(DESCRIBE)命令实例讲解
2016/09/24 PHP
php smtp实现发送邮件功能
2017/06/22 PHP
定位地理位置PHP判断员工打卡签到经纬度是否在打卡之内
2019/05/23 PHP
JavaScript获得选中文本内容的方法
2008/12/02 Javascript
js关闭模态窗口刷新父页面或跳转页面
2012/12/13 Javascript
jquery 选择器引擎sizzle浅析
2013/02/06 Javascript
js数组与字符串的相互转换方法
2014/07/09 Javascript
node.js中的console.log方法使用说明
2014/12/09 Javascript
学习JavaScript设计模式之迭代器模式
2016/01/19 Javascript
一个简单的JavaScript Map实例(分享)
2016/08/03 Javascript
ThinkJS中如何使用MongoDB的CURD操作
2016/12/13 Javascript
JavaScript实现事件的中断传播和行为阻止方法示例
2017/01/20 Javascript
Vue仿手机qq的实例代码(demo)
2017/09/08 Javascript
javascript+jQuery实现360开机时间显示效果
2017/11/03 jQuery
JS实现字符串去重及数组去重的方法示例
2018/04/21 Javascript
详解Nodejs mongoose
2018/06/10 NodeJs
jQuery插件实现的日历功能示例【附源码下载】
2018/09/07 jQuery
JS实现换肤功能的方法实例详解
2019/01/30 Javascript
优雅地使用loading(推荐)
2019/04/20 Javascript
jQuery单页面文字搜索插件jquery.fullsearch.js的使用方法
2020/02/04 jQuery
[49:41]NB vs NAVI Supermajor小组赛A组 BO3 第一场 6.2
2018/06/03 DOTA
Python实现的堆排序算法原理与用法实例分析
2017/11/22 Python
python matplotlib 画dataframe的时间序列图实例
2019/11/20 Python
解决Python logging模块无法正常输出日志的问题
2020/02/21 Python
Python面向对象实现方法总结
2020/08/12 Python
Django路由层URLconf作用及原理解析
2020/09/24 Python
最耐用行李箱,一箱永流传:Briggs & Riley(全球终身保修)
2017/12/07 全球购物
英国书籍、CD、DVD和游戏的第一道德零售商:Awesome Books
2020/02/22 全球购物
数字天堂软件测试面试题
2012/12/23 面试题
文化活动实施方案
2014/03/28 职场文书
银行先进个人事迹材料
2014/05/11 职场文书
2016简单的租房合同范本
2016/03/18 职场文书
史上最全书信经典范文大全(建议收藏)
2019/07/10 职场文书
详解Python牛顿插值法
2021/05/11 Python
微信小程序中使用vant框架的具体步骤
2022/02/18 Javascript