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限制文本框只能输入数字(正则表达式)
Jul 15 Javascript
复选框全选与全不选操作实现思路
Aug 18 Javascript
常见的原始JS选择器使用方法总结
Apr 09 Javascript
超链接的禁用属性Disabled使用示例
Jul 31 Javascript
jquery实现简单的轮换出现效果实例
Jul 23 Javascript
jQuery的Cookie封装,与PHP交互的简单实现
Oct 05 Javascript
Bootstrap基本布局实现方法详解
Nov 25 Javascript
微信小程序 参数传递实例代码
Mar 20 Javascript
Bootstrap图片轮播效果详解
Oct 17 Javascript
vue实现商城购物车功能
Nov 27 Javascript
vue使用vue-i18n实现国际化的实现代码
Apr 08 Javascript
vue v-for直接循环数字实例
Nov 07 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制作图型计数器的例子
2006/10/09 PHP
PHP 中英文混合排版中处理字符串常用的函数
2007/04/12 PHP
php实现用于验证所有类型的信用卡类
2015/03/24 PHP
PHP异常处理浅析
2015/05/12 PHP
PHP函数func_num_args用法实例分析
2015/12/07 PHP
获取JavaScript用户自定义类的类名称的代码
2007/03/08 Javascript
Kibo 用于处理键盘事件的Javascript工具库
2011/10/28 Javascript
JavaScript 垃圾回收机制分析
2013/10/10 Javascript
js对文章内容进行分页示例代码
2014/03/05 Javascript
js使用正则实现ReplaceAll全部替换的方法
2014/08/22 Javascript
javascript事件冒泡和事件捕获详解
2015/05/26 Javascript
JavaScript面向对象之私有静态变量实例分析
2016/01/14 Javascript
Vue.js双向绑定操作技巧(初级入门)
2016/12/27 Javascript
Bootstrap fileinput文件上传组件使用详解
2017/06/06 Javascript
基于Fixed定位的框选功能的实现代码
2019/05/13 Javascript
layui radio单选限制下一个radio单选的实例
2019/09/03 Javascript
Node.js之删除文件夹(含递归删除)代码实例
2019/09/09 Javascript
解决基于 keep-alive 的后台多级路由缓存问题
2020/12/23 Javascript
[56:42]VP vs RNG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
easy_install python包安装管理工具介绍
2013/02/10 Python
Python爬虫包BeautifulSoup异常处理(二)
2018/06/17 Python
python实现比较类的两个instance(对象)是否相等的方法分析
2019/06/26 Python
python中enumerate() 与zip()函数的使用比较实例分析
2019/09/03 Python
基于梯度爆炸的解决方法:clip gradient
2020/02/04 Python
mac在matplotlib中显示中文的操作方法
2020/03/06 Python
Python爬虫简单运用爬取代理IP的实现
2020/12/01 Python
利用python查看数组中的所有元素是否相同
2021/01/08 Python
pycharm配置python 设置pip安装源为豆瓣源
2021/02/05 Python
BabyBjörn婴儿背带法国官网:BabyBjorn法国
2018/06/16 全球购物
国际贸易专业个人求职信范文分享
2013/12/14 职场文书
保险公司年会主持词
2014/03/22 职场文书
2015新员工试用期工作总结
2014/12/12 职场文书
2015法院个人工作总结范文
2015/05/25 职场文书
同学会感言
2015/07/30 职场文书
2019交通安全宣传标语集锦!
2019/06/28 职场文书
3050和2060哪个好 性能差多少 差距有多大 谁更有性价比
2022/06/17 数码科技