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事件写法实现代码
Jan 07 Javascript
浅谈javascript事件取消和阻止冒泡
May 26 Javascript
javascript最基本的函数汇总
Jun 25 Javascript
javascript解决IE6下hover问题的方法
Jul 28 Javascript
JavaScript解八皇后问题的方法总结
Jun 12 Javascript
深入理解requestAnimationFrame的动画循环
Sep 20 Javascript
JS弹出窗口的运用与技巧大全
Nov 01 Javascript
原生js实现弹出层效果
Jan 20 Javascript
微信小程序 监听手势滑动切换页面实例详解
Jun 15 Javascript
深入浅析ng-bootstrap 组件集中 tabset 组件的实现分析
Jul 19 Javascript
el-form 多层级表单的实现示例
Sep 10 Javascript
vue3.0+vue-router+element-plus初实践
Dec 02 Vue.js
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利用COM对象访问SQLServer、Access
2006/10/09 PHP
给php新手谈谈我的学习心得
2007/02/25 PHP
一家之言的经验之谈php+mysql扎实个人基本功
2008/03/27 PHP
php 数组动态添加实现代码(最土团购系统的价格排序)
2011/12/30 PHP
dedecms集成财付通支付接口
2014/12/28 PHP
YII CLinkPager分页类扩展增加显示共多少页
2016/01/29 PHP
Javascript this关键字使用分析
2008/10/21 Javascript
javascript笔记 String类replace函数的一些事
2011/09/22 Javascript
javascript全局变量封装模块实现代码
2012/11/28 Javascript
jquery图片轮播插件仿支付宝2013版全屏图片幻灯片
2014/04/03 Javascript
JQuery中serialize() 序列化
2015/03/13 Javascript
jQuery简单实现仿京东商城的左侧菜单效果代码
2015/09/09 Javascript
原生js仿jquery实现对Ajax的封装
2016/10/04 Javascript
AngularJS使用ng-inlude指令加载页面失败的原因与解决方法
2017/01/19 Javascript
浅析JavaScript中var that=this
2017/02/17 Javascript
详解基于Angular4+ server render(服务端渲染)开发教程
2017/08/28 Javascript
element-ui表格列金额显示两位小数的方法
2018/08/24 Javascript
Vue数据驱动表单渲染,轻松搞定form表单
2019/07/19 Javascript
浅谈layui 绑定form submit提交表单的注意事项
2019/10/25 Javascript
[02:02]特效爆炸!DOTA2珍宝之瓶待你开启
2018/08/21 DOTA
Python中super的用法实例
2015/05/28 Python
python中关于for循环的碎碎念
2017/06/30 Python
利用pyinstaller将py文件打包为exe的方法
2018/05/14 Python
Python Json模块中dumps、loads、dump、load函数介绍
2018/05/15 Python
浅析Python四种数据类型
2018/09/26 Python
python使用magic模块进行文件类型识别方法
2018/12/08 Python
Python换行与不换行的输出实例
2020/02/19 Python
浅谈python 调用open()打开文件时路径出错的原因
2020/06/05 Python
python反编译教程之2048小游戏实例
2021/03/03 Python
艺术用品:Arteza
2018/11/25 全球购物
员工年终自我评价
2014/09/14 职场文书
小学家长意见怎么写
2015/06/03 职场文书
让生命充满爱观后感
2015/06/08 职场文书
检讨书之工作不认真
2019/08/14 职场文书
用javascript制作qq注册动态页面
2021/04/14 Javascript
在MySQL中你成功的避开了所有索引
2022/04/20 MySQL