主题:介绍引用类型Object、Array。

在上一章中,作者就在说变量的值的时候,提到过引用类型这个概念。JavaScript中存在基本类型和引用类型,其中引用类型很重要,这里有许多我们需要注意的东西。从目录中,可以看到JavaScript中的引用类型有:Object类型、Array类型、Data类型、RegExp类型、Function类型、基本内置类型、单体内置类型。下面我将整理这里的知识点。

①引用类型是一种数据结构,用于将数据和功能组织在一起,它也被称为类,但JavaScript中却不支持类和接口都基本机构,故称之为对象定义。

②Object是使用最多的一个类型。创建Object有两种方法。

第一种使用new操作符:

 var person = new Object();
person.name = "xuchaoi";
person.age = 24;

第二种使用对象字面量表示法:

 var person = {
name: "xuchaoi",
age: "24"
} // 访问对象的值:person.name

③创建Array和创建Object类似。可以通过new操作符或数组字面量表示法创建

④通过Array.isArray()方法来检测数组。因为typeof()检测数组、对象或Null类型返回的都是“object”

⑤拆分数组成字符串方法:join()

 var name = ["小明", "小红", "小青"];
consol.log(name.join("&")); // 小明&小红&小青

⑥数组模拟数据结构栈。push()向数组末尾添加值,pop()移除数组末尾项。从而实现后进先出的栈结构

⑦数组模拟数据结构对。push()向数组末尾添加值,shift()移除数组首项。从而实现先进先出的对结构

⑧unshift()与shift()相反,它向数组首项添加值

⑨数组倒序方法:reverse()。该方法会反转数组项的顺序。

⑩数组排序方法:sort()。默认情况下,它会先为数组每项进行toString()转型,然后按照升序排列数组项

 var values = [0, 1, 5, 10, 15];
console.log(value.sort()); //0,1,10,15,5

这样的结果显然不是我们想要的,这里sort()方法接受一个比较函数作为参数,以便我们控制顺序。比较函数有两个参数,分别是前一个值和后一个值。如果第一个值放在第二个值后面则返回一个正数,反之返回一个负数,无论先后返回0。

function compare(value, nextValue) {
if(value < nextValue) {
return -1;
} else if(value > nextValue) {
return 1;
} else{
return 0;
}
}
var values = [1, 0, 10, 5, 15];
console.log(values.sort(compare)); //0,1,5,10,15

⑪连接数组:concat(),接受参数:字符串、数组

⑫截取数组(不对原数组进行改变生成新数组)方法:slice()。接收连个参数:起始值,结束值(可省略)。

 var colors = ["红色", "黄色", "绿色", "蓝色"];
var colors1 = colors.slice(1); //截取从起始值到结束(数值都是从0计数)
var colors2 = colors.slice(1,3) //截取从起始值到结束值(不包括结束值)
console.log(colors1); //["黄色", "绿色", "蓝色"]
console.log(colors2); //["黄色", "绿色"]

⑬操作数组的方法:splice()。该方法可以删除数组的项,向数组中插入项,给数组替换项(即在删除数组项的同时再在相应位置添加项)

⑭数组项的位置方法:indexOf()。从数组第一项向后查我们设置的值,一旦查到就返回该值在数组中的位置索引,没有查到返回-1。利用这点可以对数组进行查重

 //原理说明:利用indexOf只会返回数组中元素首次出现的位置与filter内函数index值的不等进行筛选
var arry = [1,2,3,4,1,2,3];
var newArray = arry.filter(function(element,index,self) {
return self.indexOf(element) === index;
}); //说明:filter()会遍历数组,过滤数组不符合要求的元素
console.log(newArray); //[1,2,3,4]

⑮数组遍历map()。

 var numbers = [1, 2, 3, 4, 5];
var numbers2 = numbers.map(function(item, index, array){
return item * 2;
});
console.log(numbers2); // [2,4,6,8,10]

⑯数组遍历forEach()

 var numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(item, index, array){
array[index] = item * 2;
});
console.log(numbers); // [2,4,6,8,10]

⑰数组累积迭代方法reduce()

 var numbers = [1, 2, 3, 4, 5];
var sum = numbers.reduce(function(prev, cur, index, array) {
return prev + cur;
}); //reduce迭代函数接受4个参数:前一个值,当前值,项的索引,数组对象
console.log(sum); //

这里先说到数组,下节将继续讲述引用类型章节的注意要点!

回归JavaScript基础(五)的更多相关文章

  1. 回归JavaScript基础(六)

    主题:引用类型Date.RegExp的介绍. 上节主要主要介绍了Object.Array引用类型.这节将继续为大家介绍引用类型,并对书中的一些知识点进行总结与归纳,也借此巩固自己对JavaScript ...

  2. 回归JavaScript基础(一)

    主题:JavaScript简介. 一.JavaScript的起源 JavaScript诞生于1995年.当时,它的主要作用是处理一些输入验证操作.之前的话,都是把表单数据发送到服务器端,然后再去判断有 ...

  3. javascript基础(五)函数

    原文http://pij.robinqu.me/ 通过call和apply间接调用函数(改变this) call 和 apply带有多个参数,call和apply把当前函数的this指向第一个参数给定 ...

  4. 回归JavaScript基础(十)

    主题:创建对象 原型模式 JavaScript中的每个对象都有一个prototype属性(原型属性),这个属性是一个指针,指向一个对象,而这个对象可以由一些属性和方法组成.被指向的对象,可以是多个对象 ...

  5. 回归JavaScript基础(九)

    主题:理解对象,创建对象. 小明是一名程序猿,也是一条单身狗!他常常自嘲:每天都会有很多对象,但却没有女朋友! 多么痛的领悟.哈哈,目前比较流行的编程语言都是面向对象的语言(Object-Orient ...

  6. 回归JavaScript基础(八)

    主题:引用类型包装类.单体内置对象的介绍. 对于我们开发人员来说,JavaScript有种引用类型一定很陌生!那就是基本包装类型:Boolean.Number和String.这也不是我们的错,主要这些 ...

  7. 回归JavaScript基础(七)

    主题:引用类型Function的介绍. 今天首先说的就是Function类型.下面就是定义函数的两种方法,第一种使用函数声明语法定义,第二种使用函数表达式定义.这两种定义函数的方式几乎没有什么区别. ...

  8. 回归JavaScript基础(四)

    主题:JavaScript变量.作用域和内存问题 JavaScript的变量和别的语言比起来是与众不同的.说道变量,不得不谈他的作用域.同很多语言一样,JavaScript开发者也不用担心开发中内存的 ...

  9. 回归JavaScript基础(三)

    主题:JavaScript基本概念. 任何语言的核心必然会描述这门语言最基本的工作原理.这部分内容对我们来说,读起来很乏味,甚至会产生困意,但这部分内容却是重要的!我有幸拜读<JavaScrip ...

随机推荐

  1. Java 并发编程——volatile与synchronized

    一.Java并发基础 多线程的优点 资源利用率更好 程序设计在某些情况下更简单 程序响应更快 这一点可能对于做客户端开发的更加清楚,一般的UI操作都需要开启一个子线程去完成某个任务,否者会容易导致客户 ...

  2. Java虚拟机(四):JVM类加载机制

    1.什么是类的加载 类的加载指的是将类的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个java.lang.Class对象,用来封装类在方法区内的数据结构 ...

  3. 数据库学习---SQL基础(一)

     数据库学习---SQL基础(一) 数据库学习---SQL基础(二) 数据库学习---SQL基础(三) SQL(struct query language)结构化查询语言:一种专门与数据库通信的语言, ...

  4. PHP在使用正则表达式验证,防注入的时候要注意一下的细节

    如下:这是一个防止用户输入的数据中包含SQL的一些关键字的正则表达式 之前一直认为这写的很正确,没多大的问题,而且自己测试也没问题, 因为关键字包含 And,而如果用户输入andy的时候呢,汗,所以还 ...

  5. JavaI/O系统2

    数据流: DataInputStream,DataOutputStream.可以用于与计算机无关的格式读写java的基本数据类型以及String对象 对象流: ObjectInputStream,Ob ...

  6. cgroups简单使用

    Cgroups控制系统资源的分配(cpu.mem.io) 1.cgroups概述 CGroup是Linux内核提供的可以限制.隔离进程组 (process groups) 所使用的物理资源 (如 cp ...

  7. Keepalived配置与使用--转载

    作者: JeremyWei | 可以转载, 但必须以超链接形式标明文章原始出处和作者信息及版权声明 网址: http://weizhifeng.net/using-keepalived.html 介绍 ...

  8. Week5——团队选题&需求分析

    Deadline: 2017-10-22 10:00PM,以博客发表日期为准. 评分基准: 按时交 - 有分(团队选题-5分,,团队贡献分-5分,需求分析-10分,原型设计-10分),检查的项目包括后 ...

  9. 解决火狐浏览器安装不上Selenium IDE插件“此附加组件无法安装”

    (摘自http://blog.sina.com.cn/s/blog_14eea47cb0102w25n.html) 解决火狐浏览器安装不上Selenium IDE插件“此附加组件无法安装” 1.打开火 ...

  10. 结合after使用content

    结合after或before伪类,在元素的开头或结尾附加上一定的内容,content:""的引号中即是添加的内容,比如说我们这么写: <div>学而时习之不亦说乎< ...