JavaScript笔记——引用类型之Object类型和Function类型
《JavaScript高级程序设计》中介绍的几种JavaScript的引用类型,本文只记了Object跟Function类型
Object类型
创建对象
var person = new Object();
var person = {};
//二者效果是一样的,但使用对象字面量表示法定义对象时不会调用Object的构造函数
访问对象属性
- 点表示法
- 方括号表示法
person.name = '';
person['name'] = '';
// 方括号表示法能用变量来访问属性
var propertyName = 'name';
person[propertyName] = '';
//若属性名包含会导致语法错误的字符或关键字、保留字,可以使用方括号表示法表示
person['first name'] = '';
Array类型
Date类型
RegExp类型
Function类型
(函数是对象,函数名是指针)
定义函数
- 函数声明
- 函数表达式
- Function构造函数
//函数声明
function sum(num1, num2){
return num1 + num2;
}
//函数表达式
var sum = function(num1, num2){
return num1 + num2;
};
//使用Function构造函数,最后一个参数视为函数体(不推荐)
var sum = new Function('num1', 'num2', 'return num1 + num2');
没有重载
因为函数名是一个指针,所以JavaScript的函数没有重载,后面定义的函数会覆盖前面的定义
function add(n){
return n + 100;
}
function add(n){
return n + 200;
}
add(100); //300
var add = function(n){
return n + 100;
};
var add = function(n){
return n + 200;
};
add(100); //300
函数声明与函数表达式(解析顺序)
函数声明会先被解析,而函数表达式要等到执行至定义的那行代码才会被解析
//正常执行
alert(sum(10, 10));
function sum(n1, n2){
return n1 + n2;
}
//报错
alert(sum(10, 10));
var sum = function (n1, n2){
return n1 + n2;
};
作为值传递
function callFunction(f, args){
return f(args);
}
function add(num){
return num + 10;
}
callFunction(add, 10); //20
//在一个函数中返回另一个函数
function callFunction(){
return function(){
};
}
函数内部属性
函数内部有两个特殊对象:arguments和this
arguments
arguments.callee属性指向拥有arguments对象的函数,可用于递归调用,消除函数执行与函数名的耦合
//阶乘
function factorial(num){
if(num <= 1){
return 1;
} else {
return num * arguments.callee(num - 1); //效果相当于return num * factorial(num - 1);
}
}
var calFactorial = factorial;
factorial = function(){
return 0;
};
calFactorial(5); //120
factorial(5); //0
this
this引用的是函数执行的环境对象(当在全局作用域中调用函数,this对象引用的是window)
window.color = 'red';
var o = {color: 'blue'};
function sayColor(){
alert(this.color);
}
sayColor(); //'red'
o.sayColor = sayColor;
o.sayColor(); //'blue'
caller属性
函数对象的属性,保存着调用当前函数的函数的引用,如果是在全局作用域中调用,则值为null
function outer(){
inner();
}
function inner(){
alert(inner.caller); //或alert(arguments.callee.caller);
}
outer();
/*
弹窗显示
function outer(){
inner();
}
*/
函数属性和方法
length, prototype, call(), apply(), bind()
length
length表示函数希望接收命名参数的个数
function fn1(){}
function fn2(a){}
function fn3(a, b){}
alert(fn1.length); //0
alert(fn2.length); //1
alert(fn3.length); //2
prototype
prototype是保存引用类型所有实例方法的地方
prototype不可枚举,for-in无法遍历到
call()和apply()
用途:在特定作用域中调用函数(可扩充函数的作用域)
相当于改变函数体内this所指的对象
接收的第一个参数相同,要代替原this的对象
后面的参数是要执行函数的形参,call()逐个接收,apply()可以将参数作为数组传入
window.num = 0;
var o = {num: 10};
function add(num1, num2){
alert(num1 + num2 + this.num);
}
add.call(this, 10, 10); //20
add.call(window, 10, 10); //20
add.call(o, 10, 10); //30
add.apply(this, [10, 10]); //20
add.apply(window, [10, 10]); //20
add.apply(o, [10, 10]); //30
bind()
bind()方法会创建一个函数实例,实例的this被绑定为传入bind()中的参数(类似于call和apply第一个参数的作用)
window.color = 'red';
var o = {color: 'blue'};
function sayColor(){
alert(this.color);
}
var objSayColor = sayColor.bind(o);
objSayColor(); //'blue'
基本包装类型
单体内置对象
参考
《JavaScript高级程序设计》(第3版)
JavaScript笔记——引用类型之Object类型和Function类型的更多相关文章
- JavaScript的进阶之路(三)引用类型之Object类型和Array类型
引用类型 Object类型 function a(num){ if(num>3){ a(--num); } console.log(num); } a(5); //如何创建对象的实例 var o ...
- DATETIME类型和BIGINT 类型互相转换
项目中使用BIGINT来存放时间,以下代码用来转换时间类型和BIGINT类型 SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ========= ...
- 关于 Go 中 Map 类型和 Slice 类型的传递
关于 Go 中 Map 类型和 Slice 类型的传递 Map 类型 先看例子 m1: func main() { m := make(map[int]int) mdMap(m) fmt.Printl ...
- MIME类型和Java类型
MIME类型和Java类型 类型转换Spring Cloud Stream提供的开箱即用如下表所示:“源有效载荷”是指转换前的有效载荷,“目标有效载荷”是指转换后的“有效载荷”.类型转换可以在“生产者 ...
- Timestame类型和String 类型的转化
Timestame类型和String 类型的转化 String转化为Timestamp: SimpleDateFormat df = new SimpleDateFormat("yyyy-M ...
- Python3.x中bytes类型和str类型深入分析
Python 3最重要的新特性之一是对字符串和二进制数据流做了明确的区分.文本总是Unicode,由str类型表示,二进制数据则由bytes类型表示.Python 3不会以任意隐式的方式混用str和b ...
- Date类型和Long类型的相互转换
Date类型和Long类型的相互转换: import java.text.SimpleDateFormat; import java.util.Date; public class T { publi ...
- java中XMLGregorianCalendar类型和Date类型之间的相互转换
import java.text.SimpleDateFormat;import java.util.Date;import java.util.GregorianCalendar;import ja ...
- C#枚举类型和int类型相互转换
C#枚举类型和int类型相互转换 C# 枚举(Enum) 枚举是一组命名整型常量.枚举类型是使用 enum 关键字声明的. C# 枚举是值数据类型.换句话说,枚举包含自己的值,且不能继承或传递继承. ...
随机推荐
- NS 802.11函数分析(一)
recv函数有两个作用,不仅是接收其他节点发送的包,而且当节点接收到其他包的时候也会调用recv() 首先给出NS2中recv的源码,和一些注释: void Mac802_11::recv(Packe ...
- 自己yy的fulkson最大流算法
#include <iostream> #include <cstdio> #include <vector> using namespace std; ; //m ...
- 如何修改 SQL Server 代理主作业 (Transact-SQL)
本主题介绍了如何使用存储过程修改 Microsoft SQL Server 代理主作业. 更改作业定义计划的详细信息 1. 执行 sp_update_schedule. 在作业中添加.更改 ...
- CSS3 calc()的使用
前言: 平时在制作页面的时候,总会碰到有的元素是100%的宽度.众所周知,如果元素宽度为100%时,其自身不带其他盒模型属性设置还好,要是有别的,那将导致盒子撑破.比如说,有一个边框,或者说有marg ...
- AngularJS学习之模型
1.ng-model指令:可以将输入域的值与AngularJS创建的变量绑定,用于绑定应用程序数据到HTML控制器(input,select,textarea)的值: <div ng-app=& ...
- 单机c1000k连接
单机c1000k连接即单机实现百万连接,首先要注意的是连接是虚拟的逻辑的,连接最终落于 网卡,清晰概念才能更深入更清晰的想出问题的解决办法. 参考 http://www.ideawu.net/blog ...
- 【bzoj4513】储能表【数位DP】
本来是想去学数位DP,作死挑了这道题,爆炸... 听说正确姿势应该是去做bzoj4521[手机],听说迪克们当场都A了,Orz 然后对于4513,我只想说,一.脸.懵.逼 首先,我是无论如何都无法想到 ...
- Codeforces Round #348(VK Cup 2016 - Round 2)
A - Little Artem and Presents (div2) 1 2 1 2这样加就可以了 #include <bits/stdc++.h> typedef long long ...
- stl(set+stack) LA 3634 The SetStack Computer
题目传送门 题意:给一些对集合的操作,询问每一次操作后栈顶的集合元素个数 分析:首先{}是空的,每一次add时候,{} -> { {} }变成了有一个元素的集合,利用set和stack,map容 ...
- set UVA 11136 Hoax or what
题目传送门 题意:训练指南P245 分析:set维护,查询删除最大最小值 #include <bits/stdc++.h> using namespace std; typedef lon ...