对象参考手册

  • Array
  • Boolean
  • Date
  • Math
  • Number
  • String
  • RegExp
  • Global

前言

在js中什么都是对象(包括函数)。

函数是用来实现具体功能的代码,用一种方式把他们组织起来,就是函数。

对象是有属性和方法的一个东西,在对象中的函数就变成了方法。

this

  • 在方法中,this 指的是所有者对象
  • 单独的情况下,this 指的是全局对象:在浏览器窗口中,全局对象是 [object Window]
  • 在函数中,this 指的是全局对象:function myFunction() {return this;}
  • 在函数中,严格模式下,this 是 undefined
  • 在事件中,this 指的是接收事件的元素:<button onclick="this.style.display='none'">点击来删除我!</button>

全局作用域

不在任何函数内定义的变量就具有全局作用域。
实际上,JavaScript默认有一个全局对象window,全局作用域的变量实际上会被绑定到window的一个属性

局部作用域

由于JavaScript的局部变量作用域实际上是函数内部,我们在for循环等语句块中是无法定义具有局部作用域的变量的:

function foo() {
for (var i=0; i<100; i++) {
···
}
i += 100; // 仍然可以引用变量i
} 为了解决块级作用域,ES6引入了新的关键字let,用let替代var可以申明一个块级作用域的变量: function foo() {
var sum = 0;
for (let i=0; i<100; i++) {
sum += i;
}
i += 1; //错误,无法引用
}

解构赋值,直接对多个变量同时赋值

如果数组本身还有嵌套,也可以通过下面的形式进行解构赋值,注意嵌套层次和位置要保持一致:
let [x, [y, z]] = ['hello', ['JavaScript', 'ES6']];
x; // 'hello'
y; // 'JavaScript'
z; // 'ES6' var person = {
name: '小明',
age: 20,
gender: 'male',
passport: 'G-12345678',
school: 'No.4 middle school',
address: {
city: 'Beijing',
street: 'No.1 Road',
zipcode: '100001'
}
};
var {name, address: {city, zip}} = person;

对象定义

var person = {
firstName: "Bill",
lastName : "Gates",
id : 648,
fullName : function() {
return this.firstName + " " + this.lastName;
}
};

对象属性

objectName.property           // person.age
objectName["property"] // person["age"]
objectName[expression] // x = "age"; person[x]

对象 for...in 循环

for...in语句遍历对象的属性。

for (variable in object) {
要执行的代码
}

对象方法

  • 请使用如下语法创建对象方法:

    methodName : function() { 代码行 }
  • 请通过如下语法来访问对象方法:

    objectName.methodName()
  • 如果您访问 fullName 属性时没有使用 (),则将返回函数定义:

    name = person.fullName;

原始数据类型

  • 请使用对象字面量 {} 代替 new Object()。

  • 请使用字符串字面量 "" 代替 new String()。

  • 请使用数值字面量代替 Number()。

  • 请使用布尔字面量代替 new Boolean()。

  • 请使用数组字面量 [] 代替 new Array()。

  • 请使用模式字面量代替 new RexExp()。

  • 请使用函数表达式 () {} 代替 new Function()。

函数定义

function functionName(parameters) {
要执行的代码
}

函数表达式,在变量中保存函数表达式之后,此变量可用作函数:

var x = function (a, b) {return a * b};

匿名的自调用函数

( function () { document.getElementById("demo").innerHTML = "Hello! I called myself"; } ) ();

箭头函数

不需要 function 关键字、return 关键字和花括号:

// ES5
var x = function(x, y) {
return x * y;
}
// ES6
var x = (x, y) => x * y;
document.getElementById("demo").innerHTML = x(5, 5); // 可变参数:
(x, y, ...rest) => {
var i, sum = x + y;
for (i=0; i<rest.length; i++) {
sum += rest[i];
}
return sum;
}

map

map()方法定义在JavaScript的Array中,我们调用Array的map()方法,传入我们自己的函数,就得到了一个新的Array作为结果:
function pow(x) {
return x * x;
} var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
var results = arr.map(pow); // [1, 4, 9, 16, 25, 36, 49, 64, 81]

filter

filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素。

var arr = ['A', '', 'B', null, undefined, 'C', '  '];
var r = arr.filter(function (s) {
return s && s.trim(); // 注意:IE9以下的版本没有trim()方法
}); // ['A', 'B', 'C'] 利用filter,可以巧妙地去除Array的重复元素:
var r = arr.filter(function (element, index, self) {
return self.indexOf(element) === index;
});
去除重复元素依靠的是indexOf总是返回第一个元素的位置,后续的重复元素位置与indexOf返回的位置不相等,因此被filter滤掉了。

arguments 对象:arguments 对象包含函数调用时使用的参数数组

函数不会对参数值进行任何检查

如果调用参数时省略了参数(少于被声明的数量),则丢失的值被设置为:undefined。

x = findMax(1, 123, 500, 115, 44, 88);

function findMax() {
var i;
var max = -Infinity;
for (i = 0; i < arguments.length; i++) {
if (arguments[i] > max) {
max = arguments[i];
}
}
return max;
}

函数 Call

通过 call(),您能够使用属于另一个对象的方法,调用 person 的 fullName 方法,并用于 person2:

var person = {
fullName: function(city, country) {
return this.firstName + " " + this.lastName + "," + city + "," + country;
}
} var person1 = {
firstName:"Bill",
lastName: "Gates"
} person.fullName.call(person1, "Seattle", "USA"); apply()方法与call()方法非常相似
Math.max.apply(null, [1,2,3]); //也会返回 3
不同之处是:
apply()把参数打包成Array再传入;
call()把参数按顺序传入。
Math.max.apply(null, [3, 5, 4]); // 5
Math.max.call(null, 3, 5, 4); // 5

JavaScript 对象与函数的更多相关文章

  1. javascript 对象,函数,原型和 this

    1.对象 在javascript里,一切都是对象,包括函数自身(不是指具体的函数,而是指"Function"这个东东).例如: var fun1=new Function(&quo ...

  2. JavaScript对象,函数,作用域

    JavaScript对象 在 JavaScript中,几乎所有的事物都是对象.JavaScript 对象是拥有属性和方法的数据. var car = {type:"Fiat", m ...

  3. javascript对象和函数的几种常见写法

    /** * Created by chet on 15/12/17. */ var En= function (button,func) { //dosth,不能return alert(button ...

  4. JavaScript对象、函数、变量、字符串的处理、运算符

    一.对象 使用一种抽象的概念去描述,人{属性,方法} var car={type:"BYD",model:500,color:white,do:function(){"可 ...

  5. JavaScript对象简介(一)

    本节介绍js的9个对象:Array数组对象 Boolean(true false) Date日前对象 Math 数学对象 Number 数字对象 String 字符串对象 RegExp 正则表达式对象 ...

  6. JavaScript学习09 函数本质及Function对象深入探索

    JavaScript学习09 函数本质及Function对象深入探索 在JavaScript中,函数function就是对象. JS中没有方法重载 在JavaScript中,没有方法(函数)重载的概念 ...

  7. [原创]javascript prototype 对象 函数 <精简的美丽......>

    精简的美丽...... javascript prototype 对象 函数 在javascript中我们都知道创建一个对象使用如下代码var x = {}对象可以拥有属性和方法var x = {   ...

  8. Javascript中的函数(Function)与对象(Object)的关系

    今天我们来尝试理解Function和Object.因为这个里面有些人前期可能会搞糊涂.他们之间到底是什么关系.当然也不除外当初的我. 注意:官方定义: 在Javascript中,每一个函数实际上都是一 ...

  9. 函数可以作为Javascript对象(哈希表)的键吗

    一般Javascript书在讲解对象时,都指出Javascript中的对象可以作为哈希表,存储键值数据.通常情况下,键为字符串,如果键是数字的话,实际上在内部也会转换为字符串. 比如 var o = ...

随机推荐

  1. 对TextVIew中特定字符串设定onTouchEvent方法

    上面是Iphone备忘录的图,笔者之前接到一个需求是实现点击文本框里的数字,弹出一个类似上图的按钮,显示出复制,要求是这个按钮的位置必须是根据你点击的位置进行定位(为什么这么说,是因为我们不可能把按钮 ...

  2. sanic连接mongo

    方法一: #没有密码,就是没有用户和用户密码 settings={"MOTOR_URI":"mongodb://127.0.0.1:27017/zzy"} ap ...

  3. frp 配置多个 web 项目,无需购买域名 (访问内网可视化界面,jupyter noterbook, visdom, tensorboard)

    frp 配置多个 web 项目,无需购买域名 简单配置,参考 前言: 网上也有很多教程包括官方文档,都需要购买域名,并且把 frpc.ini 中 [web]节配置的  custom_domains 的 ...

  4. 【学术篇】SDOI2009 SuperGCD

    特别说明: 为了避免以后搬家时的麻烦, 这里的文章继续沿用csdn的风格和分类好了~ Emmmm这个题是一道高精度的模板题啊~ 既然是高精度的裸题, 那我们这些懒人当然是选择:用python啦~ 懒癌 ...

  5. Batch - 重定向符号Redirection >

    总结 Don't use a piping operator, which is what ">" Redirection is. 不要使用管道运算符,即“>”. Di ...

  6. c++ GetAsyncState() 函数

    函数原型 SHORT GetAsyncKeyState(int vKey); 例:若判断 回车键 if(GetAsyncKeyState(VK_RETURN)&0x8000) ( return ...

  7. Delphi 时间函数:关于时间精确的几个函数和方法

    //取毫秒级时间精度(方法一): var t1,t2:int64; r1:int64; begin t1:=GetTickCount;//获取开始计数 WINDOWS API sleep(1000); ...

  8. Java初识方法

    5.初识方法 方法就是一段代码片段,这个片段可以完成特定的功能,并且可以重复利用. 5.1 方法的定义 5.1.1方法的定义格式 [方法修饰列表] 返回值类型 方法名(方法参数列表){ 方法体 } ① ...

  9. R语言 基本语法

    R语言基本语法 我们将开始学习R语言编程,首先编写一个"你好,世界! 的程序. 根据需要,您可以在R语言命令提示符处编程,也可以使用R语言脚本文件编写程序. 让我们逐个体验不同之处. 命令提 ...

  10. PHP headers_list() 函数

    定义和用法 headers_list() 函数返回已发送的(或待发送的)响应头部的一个列表. 该函数返回包含报头的数组. 语法 headers_list() 提示和注释 提示:如需确定是否已发送报头, ...