引用类型
引用类型的值(对象)是引用类型的一个实例
引用类型是一种数据结构,用于将数据与功能组织在一起
也常被称为类, Object
对象的两种创建方式
使用new操作符
对象字面量表示法 Array
数组的length不是只读的,还可设置,没有被赋值的地方为undefined
检测是否为数组
console.log([] instanceof Object);//检测对象的数据类型
console.log([].constructor.name);//Array
console.log(Array.isArray([])) //true !(function () {
var people1 = {
toLocaleString(){
return 'people1.1'
},
toString(){
return 'people1.2'
}
}
var people2
= {
toLocaleString(){
return 'people21'
},
toString(){
return 'people22'
}
} var people=[people1,people2];
console.log(people);
alert(people);//people1.2,people22
alert(people.toLocaleString());//people1.1,people21 })()
!(function () {
/*栈方法(栈的插入(推入)与删除(弹出)只发生在一个位置(栈的顶部))*/
/*push()推入 pop()弹出*/
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
console.log(arr.push(0, 1, 5, 77)); //尾部增加 返回值为数组长度
console.log(arr);
console.log(arr.pop());//尾部删除 返回值是删除的内容
console.log(arr);
})() !(function () {
/*队列方法*/
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
console.log(arr.shift());//数组中移除第一项 返回值是移除的数组
console.log(arr);
console.log(arr.unshift(1, 1, 1)); //返回值为数组的长度 前面添加元素
console.log(arr)
})() !(function () {
/*重排序*/
var arr = [1, 9, 99, 4, 44, 6, 66, 5, 9];
// reverse() 翻转数组
console.log(arr.reverse());//返回值为翻转之后的数组
console.log(arr);
console.log(arr.sort());//会根据数字首数字大小排序,小到大,
console.log(arr.sort(function (a, b) {
return a - b;//正序
}));
console.log(arr.sort(function (a, b) {
return -(a - b)//倒序
})) })(); !(function () {
console.log('操作方法');
/*操作方法*/
//操作包含在数组中的项
var arr = [1, 2, 3];
console.log(arr);
/*concat()会创建当前数组的一个副本然后将接受到的参数天津爱到这个副本的末尾最后但是重新构建的数组*/
console.log(arr.concat(11, 22, 33, [444, 555], {name: 'hxq'})); //返回值为改变之后的数组 因为赋值了一个对象副本,所以不改变原数组
//可添加多个参数,数组会直接加入其中每个元素,但是对象就是添加对象 (9) [1, 2, 3, 11, 22, 33, 444, 555, {…}];
console.log(arr);//[1, 2, 3] /*slice()
* 基于当前数组的一个或者多个项(不会改变原数据)
**/
console.log(arr.slice(1, 2));//数组的截取 从第一位到第二位
console.log(arr); //[1, 2, 3]
console.log(arr.slice(-3, -1));//从倒着数第三位到倒着数第一位截取 ,
//如果参数一大于参数二 则返回的是空数组 /*splice()*/
//一个强大的方法有很多用法
/*
* 一个参数:从参数一节渠道最后一位;
* 两个参数:从参数一往后截取参数二位,
* 三个参数或更多:参数一往后就去参数二位,将后面的元素替换掉截取的部分
* */
console.log('splice');
var arr1 = [1, 2, 3, 4, 5, 6, 7, 8, 9];
console.log(arr1.splice(2, 4));//[3, 4, 5, 6] (从第二位开始往后截取四位)
console.log(arr1);//[1, 2, 7, 8, 9] (原数组会受到改变)
console.log(arr1.splice(1));
console.log(arr1);
var arr2 = [1, 2, 3, 4];
console.log(arr2.splice(1, 2, 88, 88, 88));
console.log(arr2); })() !(function () {
// 位置方法
/* indexOf()
* lastIndexOf()
* 用的是=== 做比较
* 参数一:要查找的元素;
* 参数二:从第几个元素开始查找
* */
console.log('位置方法');
var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
console.log(arr.indexOf(4, 3));
console.log(arr.lastIndexOf(2)); })() !(function () {
/*数组的迭代方法
* every() ; 数组中所有元素满足迭代条件则为true;
* some() ;数组咋弄有一个元素满足迭代器条件则返回true
* filter() ;返回满足条件得数组;
* forEach() ;遍历操作,本质上与for循环一致
* map() ;遍历操作 返回的数组中每个元素都可以在迭代器中修改
* */
console.log('迭代方法');
var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
var result = arr.every(function (v,k,ele) {
console.log(1);
return v>-2;//必须要有这句 不然不会迭代
})
console.log(result);//数组中每个元素都满足迭代中的条件则为true; result=arr.filter(function (v,k,ele) {
return v>5;
});
console.log(result); })()
!(function () {
/*归并方法
* reduce()
* 参数1:第一次遍历是数组的第一项,然后就是迭代器返回的值
* 参数2:从数组的第二项开始一直往后
* 参数3:参数2的下标
* 参数4:数组本身
* 返回值是最后的返回值
* reduceRight()
* */
console.log('归并');
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]; // var result=arr.reduce(function (a,b,c,d) {
//
//// console.log(1);//里面执行的次数是数组的长度-1次
// console.log(a,b,c,d);
// return a+b;
// })
// console.log(result)
var result=arr.reduceRight(function (a,b,c,d) {
//
// console.log(1);//里面执行的次数是数组的长度-1次
console.log(a,b,c,d);
return a+b;
})
console.log(result)
})()

第五章:引用类型(一)-Object和Array的更多相关文章

  1. 读JS高级——第五章-引用类型 _记录

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. JavaScript高级程序设计学习笔记第五章--引用类型(函数部分)

    四.Function类型: 1.函数定义的方法: 函数声明:function sum (num1, num2) {return num1 + num2;} 函数表达式:var sum = functi ...

  3. JAVASCRIPT高程笔记-------第五章 引用类型

    一.Object类型 1.1创建方式 ①new关键字 : var person = new Oject(); ②给定直接量: var person = { name : "zhangsan& ...

  4. 浅析JavaScript引用类型之--Object、Array

    1.Object类型 对象是某个特定引用类型的实例,新对象有两种创建方式: i.使用new操作符调用构造函数来创建. var person = new Object(); person.name = ...

  5. Javascript高级程序设计复习——第五章引用类型 【原创】

    5.1  Object类型 1:创建Object实例的两种方式 ①new构造法 var obj1 = new Object(); 注意大写!不传递参数时可以省略圆括号 obj1.hehe = &quo ...

  6. JavaScript高级程序设计学习笔记第五章--引用类型

    一.object类型 1.创建object类型的两种方式: 第一种,使用构造函数 var person = new Object();或者是var person={};/与new Object()等价 ...

  7. 引用类型(object、array)

    1.Object类型 1)创建方法: //使用new加object构造函数 var person = new Object(); person.name = "aaa"; pers ...

  8. Javascript高级程序设计笔记 <第五章> 引用类型

    一.object类型 创建object实例的方式有两种: //第一种使用new操作符跟构造函数 var person= new Object(); person.name="小王" ...

  9. 小红书第五章——引用类型之function类型

    有趣的函数——function类型 函数实际上是对象,每个函数都是function类型的实例,具有属性和方法. 1.函数的定义方法 1)函数声明语法 function sum(num1,num2){/ ...

  10. 读书笔记 - js高级程序设计 - 第五章 引用类型

      引用类型 和 类 不是一个概念 用typeof来检测属性是否存在 typeof args.name == "string"  需要实验 访问属性的方法 .号和[] 一般情况下要 ...

随机推荐

  1. JavaScript问题01 js代码放在header和body的区别

    1 body和header中JavaScript执行的时机 1.1 header中 放在header中的javascript代码会进行预加载(即:在页面加载之前就会进行),所以需调用才执行的脚本或事件 ...

  2. Luogu 4281 [AHOI2008]紧急集合 / 聚会

    BZOJ 1832 写起来很放松的题. 首先发现三个点在树上一共只有$3$种形态,大概长这样: 这种情况下显然走到三个点的$lca$最优. 这种情况下走到中间那个点最优. 这种情况下走到$2$最优. ...

  3. Shell表达式,如${file##*/}

    Shell表达式,如${file##*/} 2017年10月26日 15:24:40 阅读数:343 今天看一个脚本文件的时候有一些地方不太懂,找了一篇文章看了一些,觉得不错,保留下来. 假设我们定义 ...

  4. Entity Framework Tutorial Basics(34):Table-Valued Function

    Table-Valued Function in Entity Framework 5.0 Entity Framework 5.0 supports Table-valued functions o ...

  5. 学会使用postman工具模拟请求-----待补充

    登录: backstop 密码:backstop的密码 记得加上header,在swagger中有content-type. 请求,则是api下对应的请求. get请求直接加入链接即可. post请求 ...

  6. 数据结构 queue

    问题描述 t 个团队在餐厅前准备排队. 他们的排队规则是:初始队伍为空.一个人要排进队伍前, 先搜索队伍中是否有他的队友. 如果有, 这名成员就直接站在最后一个队友的后面,如果没有,那么这名成员只能排 ...

  7. 解决批处理命令执行完毕后自动关闭cmd窗口方法

    问题描述: 日常开发工作中,为了节省多余操作导致浪费时间,我们经常会自己建一些批处理脚本文件(xx.bat),文件中包含我们需要执行的命令,有时候我们希望执行完毕后看一下执行的结果,但是窗口执行完毕后 ...

  8. WPF开源界面库

    WPF开源项目 WPF有很多优秀的开源项目,我以为大家都知道,结果,问了很多人,其实他们不知道.唉,太可惜了! 先介绍两个比较牛逼的界面库 1.MaterialDesignInXamlToolkit ...

  9. kylin 连接 hortonworks 中的 hive 遇到的问题

    用 hortonworks(V3.1.0.0) 部署了 ambari (V2.7.3),用 ambari 部署了 hadoop 及 hive. 1.  启动 kylin(V2.6)时,遇到如下问题: ...

  10. 【bzoj1951】: [Sdoi2010]古代猪文 数论-中国剩余定理-Lucas定理

    [bzoj1951]: [Sdoi2010]古代猪文 因为999911659是个素数 欧拉定理得 然后指数上中国剩余定理 然后分别lucas定理就好了 注意G==P的时候的特判 /* http://w ...