js红宝书学习笔记(一)引用类型
一.引用类型
ECMAScript中,引用类型是一种数据结构称之为对象定义,,引用对象不同于传统面向对象语言所支持的类和接口等基本结构
创建Object 实例的两种方式:
new操作符跟Object构造函数
-
var person = new Object();
-
person.name ="Nicholas";
-
person.age=29;
对象字面量表示法
向函数传递大量可选参数的首选方式
-
var person = {
-
name :"Nicholas",
-
age:29
-
};
例子:
-
function displayInfo(args){
-
var output="";
-
if(typeof args.name=="String"){
-
output += "Name:" + args.name;
-
}
-
if(typeof args.age=="number"){
-
output += "Age:" + args.age;
-
}
-
alert(output);
-
}
-
-
dispalyInfo({
-
name: "Nicholas",
-
age: 29
-
})
-
-
displayInfo({
-
name: "Greg"
-
});
2.Array类型
ECMAScript数组与其他语言中的数组都是数据的有序列表,与其他语言不同的是,ECMAScript数组的每一项都可以保存任何类型的数据
创建数组的两种方式:
- 使用Array构造函数
-
var colors = new Array();
-
var colors = new Array(20);// 创建一个包含 20 项的数组
-
var colors = new Array("red", "blue", "green"); 创建一个包含 3 项,即字符串""red", "blue", "green"的数组
- 使用数组字面量表示法
-
var colors = ["red", "blue", "green"]; // 创建一个包含 3 个字符串的数组
-
var names = []; // 创建一个空数组
-
var values = [1,2,]; // 不要这样!这样会创建一个包含 2 或 3 项的数组
-
var options = [,,,,,]; // 不要这样!这样会创建一个包含 5 或 6 项的数组
数组的项数可以增加--减少
-
var colors=["red","blue","green"];//定义一个字符串数组
-
alert(colors[0]);显示第一项
-
colors[2] ="black"//修改第三项
-
colors[3] ="brown";// 新增第四项
-
----数组就会自动增加到该索引值加 1 的长度
-
var colors =["red","blue","green"]// 创建一个包含 3 个字符串的数组
-
colors.length = 2;
-
alert(colors[2]);
3.判断对象是不是数组的经典问题
-
if(value instanceof Array){
-
//对数组执行某些操作
-
}
存在问题:
他假定只有一个全局执行环境。如果网页中包含多个框架,实际上存在两个以上不同全局执行环境,从而存在两个不同版本的Array构造函数
解决方案:
-
if(Array.isArray(Value)){
-
}
-
var colors=["red","blue","green"]
-
alert(colors.toString());// red,blue,green
-
alert(colors.valueOf()); // red,blue,green
-
alert(colors); // red,blue,green
-
var colors=["red","green","blue"];
-
alert(colors.join(","));//red,green,blue
-
alert(colors.join("||")); //red||green||blue
二.栈方法
- 栈是一种LIFO(Last-In-First-Out)后进先出的数据结构,最新添加的项最早被移除
- 栈中项的插入(推入)和移除只发生在栈的顶部
push方法和pop方法
-
var colors=new Array();//创建一个数组
-
var count=colors.push("red","green");//推入两项
-
alert(count); //2
-
count = colors.push("black"); // 推入另一项
-
alert(count); //3
-
var item = colors.pop(); // 取得最后一项
-
alert(item); //"black"
-
alert(colors.length); //2
三.队列方法
- 栈数据结构----LIFO(后进先出) push方法和pop方法
- 队列数据结构--FIFO(先进先出)push方法和shift方法
-
var colors = new Array(); //创建一个数组
-
var count = colors.push("red", "green"); //推入两项
-
alert(count); //2
-
count = colors.push("black"); //推入另一项
-
alert(count); //3
-
var item = colors.shift(); //取得第一项
-
alert(item); //"red"
-
alert(colors.length); //2
- unshifit():数组前端添加任意各项并返回新数组长度
- unshift()和pop方法,可以相反的方向模拟队列,即在数组的前端添加项,在数组的末端移除项
四.迭代方法
- filter():对数组中的每一项运行给定函数,返回该函数会返回 true 的项组成的数组。
- forEach():对数组中的每一项运行给定函数。这个方法没有返回值。
- map():对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
- some():对数组中的每一项运行给定函数,如果该函数对任一项返回 true,则返回 true。
- every():对数组中的每一项运行给定函数,如果该函数对每一项都返回true,则返回true。
-
var numbers = [1,2,3,4,5,4,3,2,1];
-
var everyResult = numbers.every(function(item, index, array){
-
return (item > 2);
-
});
-
alert(everyResult); //false
-
var someResult = numbers.some(function(item, index, array){
-
return (item > 2);
-
});
-
alert(someResult); //true
-
-
var numbers = [1,2,3,4,5,4,3,2,1];
-
var filterResult = numbers.filter(function(item, index, array){
-
return (item > 2);
-
});
-
alert(filterResult); //[3,4,5,4,3]
-
-
var numbers = [1,2,3,4,5,4,3,2,1];
-
var mapResult = numbers.map(function(item, index, array){
-
return item * 2;
-
});
-
alert(mapResult); //[2,4,6,8,10,8,6,4,2]
-
-
var numbers = [1,2,3,4,5,4,3,2,1];
-
numbers.forEach(function(item, index, array){
-
//执行某些操作
-
});
reduce()和reduceRight()函数
-
var values = [1,2,3,4,5];
-
var sum = values.reduce(function(prev, cur, index, array){
-
return prev + cur;
-
});
-
alert(sum); //15
五.Function 类型
- 函数名实际上是一个指向函数对象的指针,不会与某个函数绑定。
- 函数通常使用函数声明语法定义
函数是对象,函数名是指针
函数定义的两种方式:
-
function sum (num1, num2) {
-
return num1 + num2;
-
}
-
-
var sum = function(num1, num2){
-
return num1 + num2;
-
};
-
-
var sum = new Function("num1", "num2", "return num1 + num2"); // 不推荐
六.没有重载
- 两个同名函数,而结果则是后面的函数覆盖了前面的函数
- 在创建第二个函数时,实际上覆盖了引用第一个函数的变量
七.基本包装类型
引用类型与基本包装类型的主要区别是对象的生存期
- 使用new操作符创建的引用类型实例,会存在内存种直到销毁
- 自动创建的基本包装类型的对象,只存在于代码执行的瞬间,然后被立即销毁
八.Boolean类型(建议不要使用Boolean对象)
js红宝书学习笔记(一)引用类型的更多相关文章
- OpenGL红宝书学习笔记(1)
OpenGL对场景中的图像进行渲染时所执行的主要操作: 1.根据几何图元创建形状,从而建立物体的数学描述,(OpenGL把点,直线,多边形和位图作为基本的图元) 2.在三维空间中排列物体,并选择观察复 ...
- 第5章 引用类型---JS红宝书书摘系列笔记
在ECMAScript中,引用类型是一种数据结构,用于将数据和功能组织在一起,描述的是一类对象所具有的属性和方法.而对象是某个特定引用类型的实例. 一.Object类型 可以通过Object构造函数创 ...
- 第4章 变量、作用域和内存---JS红宝书书摘系列笔记
一.基本类型和引用类型 ECMAScipt变量可能分为两种数据类型:基本类型和引用类型. 基本类型:指简单的数据段:包括Undefined.Null.Boolean.Number.String:可以操 ...
- JS红宝书笔记——第一章 JavaScript简介
1.JavaScript简史 Netscape公司决定开发一种客户端语言用来处理浏览器端简单的表单验证. Netscape公司派布兰登·艾奇(BrendanEich)为计划于1995年2月发布的Net ...
- 【转载】关于在vs2013中配置opengl红宝书第八版环境
本文为转载 原文地址 http://blog.csdn.net/qq821869798/article/details/45247241 本人刚开始学习opengl,买了一本opengl红宝书第八版 ...
- OpenGl编程指南第7版(红宝书)环境配制
环境 OS:win7 旗舰版SP1 64位 编译器: VS 2013 express 的cl 软件 glut. 在这个页面https://www.opengl.org/resources/librar ...
- 《JS高程》事件学习笔记
事件:文档或浏览器窗口中发生的一些特定的交互瞬间,也即用户或浏览器自身执行的某种动作. -------------------------------------------------------- ...
- 从今日起,我会把OpenGL红宝书上的例子用完整的代码形式写在我的博客中,
1.使用教程:OpenGL红宝书第8版 2.使用的库工具:GLEW和GLFW 3.使用的IDE:vs2012 4.说说目的:完整的看一遍OpenGL,加深印象并且熟练掌握运用OpenGL 5.欢迎有相 ...
- [转] VS2015中跑OpenGL红宝书第八版的第一章示例代码,运行
Ori Article Link OpenGL的东西快忘光了,把角落的第八版红宝书拿出来复习一下 从书中的地址下了个示例代码结果新系统(Win10+VS2015)各种跑不起来,懊恼之后在网上疯狂搜索资 ...
随机推荐
- 云图说丨初识华为云微服务引擎CSE
摘要:微服务引擎(Cloud Service Engine,CSE),是用于微服务应用的云中间件,为用户提供注册发现.服务治理.配置管理等高性能和高韧性的企业级云服务能力 本文分享自华为云社区< ...
- playwright录制脚本
我喜欢Playwright! 这是微软开源的一款非常强大的自动化工具,再过几年,他很有可能取代Selenium在浏览器自动化的通知地位.使用过一段时间,我没有找到很好的中文资料可以参考,导致很多问题无 ...
- Luogu1382 楼房 (线段树 扫描线)
各种低级错误.jpg,数组开大就过.jpg 线段树离散化扫描线 #include <iostream> #include <cstdio> #include <cstri ...
- 在Mac上利用压测工具Jmeter-Suite进行一次压测实践的保姆级详细步骤(参考腾讯云文章)
参考的文章 压测工具Jmeter-Suite详细操作步骤 写此文的目的 由于我是刚开始接触kubernetes和jmeter,所以在学习过程中遇到了很多很多问题,同时我很烦恼为什么网上没有文章是从真正 ...
- 浅谈 Raft 分布式一致性协议|图解 Raft
前言 本篇文章将模拟一个KV数据读写服务,从提供单一节点读写服务,到结合分布式一致性协议(Raft)后,逐步扩展为一个分布式的,满足一致性读写需求的读写服务的过程. 其中将配合引入Raft协议的种种概 ...
- tty的crash分析
crash> btPID: 410629 TASK: ffff883fea379fa0 CPU: 10 COMMAND: "jupyter-lab"#0 [ffff8823c ...
- Spring源码-入门
一.测试类 public class Main { public static void main(String[] args) { ApplicationContext applicationCon ...
- 牛客CSP-S模拟题——十二桥问题
题面 n <= 50000,m <= 200000,k <= 12 题解 可以从K条边的两端和1结点出发各进行一次O(nlogn)的Dijk,然后就浓缩成了一个最多只有25个点的小完 ...
- C语言【10部分】
输出整数 #include <stdio.h> int main() { int number; // printf() 输出字符串 printf("输入一个整数: " ...
- centos7部署k8s(1master1node)
〇.前言 就想多学学罢了 准备环境: centos7 master 8GB 172.26.130.204 centos7 node 8GB 172.26.130.205 yum源就阿里源就好... 一 ...