JavaScript学习随记——数组一

数组的创建及length属性

		<script type="text/javascript" charset="utf-8">// 数组创建方式一,此种方式写的时候比较麻烦var arr=new Array();// 数组创建方式二var arr= [1,2,3,4,true,'str',new Date()];console.log("arr.length:"+arr.length);console.log(arr);arr.length=5;		// 指定组数长度后,数组长度以外的元素则会被裁减掉console.log("arr.length:"+arr.length+"  ,arr:"+arr);	console.log(arr[6]);/************************* 运行结果 *************************arr.length:7[1, 2, 3, 4, true, "str", Date {Thu Oct 15 2015 00:08:43 GMT+0800}]arr.length:5  ,arr:1,2,3,4,trueundefined**********************************************************/</script>
注意:数组的使用时注意如果指定了数据的长度的,则数组长度外的元素会被裁减掉(内存中被干掉)。

数组的 push 和 pop 方法

		<script type="text/javascript" charset="utf-8">/***  数组的 push 和 pop 方法*  和数据结构中的栈(先进后出)的操作一样,推入,压出*/var arr=[];arr.push(4); //推入arr.push(3,2);arr.push(2);var returnVal=arr.push(true);	//返回值为新数组的长度arr.push(new Date())console.log(returnVal);console.log("arr.length: "+arr.length);console.log("arr: "+arr);arr.pop();	// 从数组尾部删除一个元素,返回值为移出的元素值console.log("arr.length: "+arr.length);console.log("arr: "+arr);/************************* 运行结果 *************************5arr.length: 6arr: 4,3,2,2,true,Thu Oct 15 2015 00:14:23 GMT+0800arr.length: 5arr: 4,3,2,2,true**********************************************************/</script>


注:pop() 和 push()对数据的操作是从数组的后面进行操作,与 shift () 和unshift() 操作位置正好相反(在数组的前面前面进行相应的移出和插入操作)。


数组的 shift 和 unshift 方法

			<script type="text/javascript" charset="utf-8">/*** shift 和 unshift 方法* shift: 从数组前移出元素* unshift: 从数组前插入*/var arr=[3,5,7,true,new Date(),undefined,null];console.log("[操作前]: "+arr);var r1=arr.shift();console.log(arr);console.log(r1);var r2=arr.unshift(0);console.log(arr);console.log(r1);/************************* 运行结果 *************************[操作前]: 3,5,7,true,Thu Oct 15 2015 00:20:43 GMT+0800,,[5, 7, true, Date {Thu Oct 15 2015 00:20:43 GMT+0800}, undefined, null]3[0, 5, 7, true, Date {Thu Oct 15 2015 00:20:43 GMT+0800}, undefined, null]3**********************************************************/</script>


数组的 splice(拼接、接合) 和 slice方法

			<script type="text/javascript" charset="utf-8">/*** splice(拼接、接合) 和 slice(切开、切下)方法* * splice(arg1,arg2,arg3...): 从arg1处截掉arg2个元素,再将arg3...之后的元素追加在截断的位置* 			arg1:操作的起始位置,从0开始* 			arg2:截掉元素个数* 			arg3:追加的元素* 			... :追加的元素* 可以理解为子元素的替换,将arg1处开始后连续arg2个元素替换成 arg3、arg4、、、* * slice(startIndex,endIndex):截取并返回数组中索引从startIndex 到 endIndex的元素(左闭右开区间,不影响别操作的对象),类似于高级语言中的字符串求子串;* * 区别:splice 操作会影响操作的对象,slice则不会影响操作的对象* */var arr=[0,1,2,3,4,5,6,7,8];console.log("[操作前]: "+arr);var r1=arr.splice(1,2,33,44,55,88,99);		//返回值为截掉的元素console.log("[操作返回值]: "+r1);					//Array [ 1, 2 ]console.log("[操作后]: "+arr);		//Array [ 0, 33, 44, 55, 88, 99, 3, 4, 5, 6, 7, 8 ]var arr=[0,1,2,3,4,5,6,7,8];console.log("[操作前]: "+arr);var r2=arr.splice(2,4);		//从第2个索引位置开始截去4个元素,截取范围是左闭右开区间console.log("[操作返回值]: "+r2);			//Array [ 2, 3, 4, 5 ]console.log(arr);			//Array [ 0, 1, 6, 7, 8 ]var arr=[0,1,2,3,4,5,6];console.log("[操作前]: "+arr);		//[操作前]: 0,1,2,3,4,5,6var result=arr.slice(2,5);			//索引从2到5左闭右开区间的元素值,对被操作的对象无影响console.log("[操作返回值]: "+result);	//[操作返回值]: 2,3,4console.log("[操作后]: "+arr);		//[操作后]: 0,1,2,3,4,5,6/************************* 运行结果 *************************[操作前]: 0,1,2,3,4,5,6,7,8[操作返回值]: 1,2[操作后]: 0,33,44,55,88,99,3,4,5,6,7,8[操作前]: 0,1,2,3,4,5,6,7,8[操作返回值]: 2,3,4,5[0, 1, 6, 7, 8][操作前]: 0,1,2,3,4,5,6[操作返回值]: 2,3,4[操作后]: 0,1,2,3,4,5,6**********************************************************/</script>



数组的 concat 和 join方法

			<script type="text/javascript" charset="utf-8">			/*** concat : 数组拼接* 注意:concat方法并不影响被操作对象本身* * join : 数组元素之间加入相应的连接元素然后返回最终的结果* 注意:join 方法也不影响被操作对象本身* */var arr1=[1,2,3];var arr2=[4,5,6];var result = arr1.concat(arr2);console.log("arr1: "+arr1);		//arr1: 1,2,3console.log("arr2: "+arr2);		//arr2: 4,5,6console.log("arr1.concat(arr2): "+result);		//arr1.concat(arr2): 1,2,3,4,5,6var arr1=[1,2,3];var result = arr1.join('-');console.log("arr1: "+arr1);		//arr1: 1,2,3console.log("arr1.join('-'): "+result);		//arr1.concat(arr2): 1-2-3console.log("arr1[2]: "+arr1[2]);			//3/************************* 运行结果 *************************arr1: 1,2,3arr2: 4,5,6arr1.concat(arr2): 1,2,3,4,5,6arr1: 1,2,3arr1.join('-'): 1-2-3arr1[2]: 3**********************************************************/</script>


数组的 sort 方法

			<script type="text/javascript" charset="utf-8">					/*** sort(): 将数组类元素进行排序,排序方式是类似字典排序的方式来进行相应的排序,而不是按数学的由小到大排序* 注意:排序后影响被操作对象*/var arr1=[1,7,5,3,10];console.log("[操作前]:"+arr1);			//[操作前]:1,7,5,3,10var result1=arr1.sort();console.log("[操作结果]:"+result1);		//[操作结果]:1,10,3,5,7console.log("[操作后]:"+arr1);			//[操作后]:1,10,3,5,7/************************* 运行结果 *************************[操作前]:1,7,5,3,10[操作结果]:1,10,3,5,7[操作后]:1,10,3,5,7**********************************************************/</script>


数组的 reverse方法

			<script type="text/javascript" charset="utf-8">	/*** reverse(): 是将数组顺序颠倒过来*/var arr2=[5,1,8,3,5];					console.log("[操作前]:"+arr2);var result2=arr2.reverse();				//[操作前]:5,1,8,3,5console.log("[操作结果]:"+result2);		//[操作结果]:5,3,8,1,5console.log("[操作后]:"+arr2);			//[操作后]:5,3,8,1,5/************************* 运行结果 *************************[操作前]:5,1,8,3,5[操作结果]:5,3,8,1,5[操作后]:5,3,8,1,5**********************************************************/</script>


案例一:实现对数组的数学排序

			<script type="text/javascript" charset="utf-8">		/*** 数学排序* 实现:对sort()方法给指定一个排序方式即可*/var arr1=[1,7,5,3,10];// 比较器function compare(var1,var2){if(var1<var2){return -1;}else if(var1>var2){return 1;}else{return 0;}}arr1.sort(compare);console.log(arr1);	// Array [ 1, 3, 5, 7, 10 ]/************************* 运行结果 *************************[1, 3, 5, 7, 10]**********************************************************/</script>

以上代码的运行环境均是Firfox,输出结果到console中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373695.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring和石英:多作业计划服务

作业调度对于应用程序来说是如此重要。 尤其是在大型项目中&#xff0c;处理大量工作可能是一个问题。 Spring和Quartz为解决该问题带来了巨大的好处。 本文介绍了如何通过使用Spring和Quartz轻松地计划多个作业。 二手技术&#xff1a; JDK 1.6.0_21 春天3.1.1 石英1.8.5 M…

反射的简单应用

首先有一个类 1 using System;2 using System.Collections.Generic;3 using System.Linq;4 using System.Text;5 using System.Threading.Tasks;6 7 namespace ConsoleApplication18 {9 public class demo 10 { 11 public string name "程序员"; 12…

JavaFX 2.0示例介绍书

我最近完成了有关JavaFX 2.0 SDK新版本的书的编写&#xff0c;并且已经将它放在您附近的书店&#xff08; Amazon &#xff09;的书架上。 该书将逐步指导您完成JavaFX 2.0的来龙去脉。 当您遇到一章时&#xff0c;将看到一些菜谱&#xff0c;这些菜谱将带来一个问题&#xff0…

双纵坐标的绘图命令_工程师绘图必备软件——OriginLab 2019b

点击右上角关注&#xff0c;尽享后续精品软件OriginLab 2019b是OriginLab OriginPro 2019版本的加强版&#xff0c;这个软件对于许多人来讲并不陌生&#xff0c;可以说是科学家和工程师的绘图必备软件。新的版本也带来许多改变&#xff0c;软件拥有多种功能&#xff0c;这个版本…

Spring远程支持和开发RMI服务

Spring远程支持简化了启用远程服务的开发。 当前&#xff0c;Spring支持以下远程技术&#xff1a;远程方法调用&#xff08;RMI&#xff09;&#xff0c;HTTP调用程序&#xff0c;Hessian&#xff0c;Burlap&#xff0c;JAX-RPC&#xff0c;JAX-WS和JMS。 远程方法调用&#xf…

ToString:身份哈希码的十六进制表示形式

我以前在方便的Apache Commons ToStringBuilder上写过博客&#xff0c;最近有人问我&#xff0c;在生成的String输出中出现的看似神秘的文本是什么构成的。 询问该问题的同事正确地推测出他正在查看的是哈希码&#xff0c;但与他实例的哈希码不匹配。 我解释说ToStringBuilder将…

登录id 黑苹果_黑苹果MacOSCatalina无法登录AppStore修复

先上图&#xff1a;惨红色的提示信息&#xff0c;把你拒之App Store门外&#xff0c;但是对之放弃、不与之斗争不是我们的节奏&#xff0c;请看破敌攻略&#xff1a;1.查看你的“关于本机”-->“概览”-->“系统报告”&#xff0c;如图&#xff1a;找到你的“网络”-->…

Web开发的入门指导

Web开发的入门指导web开发编程技术你点开此文&#xff0c;说明你对Web开发是有兴趣的&#xff0c;或者你正在思考开始学习Web开发。在这里&#xff0c;我会告诉你成为一名Web开发者的路线&#xff0c;是对初学者关于Web开发的指导。这篇文章不会教你如何写代码&#xff0c;而是…

过滤日志中不相关的堆栈跟踪行

我喜欢堆栈痕迹。 不是因为我喜欢错误&#xff0c;而是因为发生错误的那一刻&#xff0c;堆栈跟踪是无价的信息源。 例如&#xff0c;在Web应用程序中&#xff0c;堆栈跟踪向您显示完整的请求处理路径&#xff0c;从HTTP套接字到过滤器&#xff0c;Servlet&#xff0c;控制器&a…

Dijkstra 最短路算法(只能计算出一条最短路径,所有路径用dfs)

上周我们介绍了神奇的只有五行的 Floyd 最短路算法&#xff0c;它可以方便的求得任意两点的最短路径&#xff0c;这称为“多源最短路”。本周来来介绍指定一个点&#xff08;源点&#xff09;到其余各个顶点的最短路径&#xff0c;也叫做“单源最短路径”。例如求下图中的 1 号…

2016给自己一个交代

一、前言 在关于技术上的学习&#xff0c;常常有这样那样的计划&#xff0c;而最终一个都没有真正的落实。零散的学习&#xff0c;终究需要系统总结&#xff0c;才能使自己有所沉淀。从毕业至今&#xff0c;我一直在忙碌&#xff0c;为公司付出自己的很多很多&#xff0c;却只不…

建模步骤_古建设计 | sketchup建模步骤教程(简易入门版)

前言本篇教程主要是针对古建建模入门者。小N给大家分享一套我相对简易的建模步骤。(PS&#xff1a;但是估计有些人可能会感觉我做的东西已经繁琐了……)因为主要是为了让大家熟悉、入门和好记忆。所以讲的东西&#xff0c;小N我会相对简单&#xff0c;有些细节的内容不会更多展…

Linux下面的IO模型

1. Linux下的五种I/O模型 阻塞I/O模型&#xff1a; 一直阻塞 应用程序调用一个IO函数&#xff0c;导致应用程序阻塞&#xff0c;等待数据准备好。 如果数据没有准备好&#xff0c;一直等待….数据准备好了&#xff0c;从内核拷贝到用户空间,IO函数返回成功指示。 我们 第一…

PIT和TestNG突变测试简介

变异测试是一种技术&#xff0c;它可以发现测试未涵盖代码的哪些部分。 它类似于代码覆盖范围 &#xff0c;但变异测试不限于在测试期间执行给定行的事实。 这个想法是修改生产代码&#xff08;引入突变&#xff09;&#xff0c;这应该改变其行为&#xff08;产生不同的结果&am…

系统架构的演变 -----自 罗文浩

转自&#xff1a;https://my.oschina.net/lwhmdj0823/blog/617713版权声明&#xff1a;罗文浩所有摘要: 一个成熟的大型网站&#xff08;如淘宝、京东等&#xff09;的系统架构并不是开始设计就具备完整的高性能、高可用、安全等特性&#xff0c;它总是随着用户量的增加&#x…

前端请求接口post_前端如何优雅地模拟接口请求?(给你的代码加点小意外)

前言&#xff1a;作为一名前端开发程序猿&#xff0c;每天都被产品经理催着开发&#xff0c;项目一启动&#xff0c;产品就过来了。嘘寒问暖&#xff1a;大胸弟&#xff0c;你啥时开始做啊&#xff1f;一般我们都会直接告诉TA&#xff0c;你先找接口解决数据问题。而我们也会经…

java mongodb 返回所有field_JAVA高级之反射

更多精彩&#xff0c;请点击上方蓝字关注我们&#xff01;今天跟大家分享JAVA高级之反射的知识。一、什么是反射反射就是把Java类中的各个成分映射成一个个的Java对象。即在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所以属性和方法&#xff1b;对于…

Linux入门笔记——cal、date、free、clear、history、man、whatis、uname

1、cal 显示日历2、date 显示系统当前的日期和时间3、df查看磁盘剩余空间的数量&#xff0c;常用参数 -h &#xff08;human&#xff09;人性化显示内容4、free显示空闲内存的数量&#xff0c;常用参数 -h &#xff08;human&#xff09;人性化显示内容5、clear清除控制终端显示…

Ueditor的配置及使用

Ueditor官网&#xff1a;http://ueditor.baidu.com/website/ &#xff08;项目需要JSP版本&#xff1a;UTF-8版&#xff09; 1.配置 <script type"text/javascript" charset"utf-8">window.UEDITOR_HOME_URL "${ctx}/assets/plugins/uedi…

努比亚z17s刷原生安卓_电脑运行手机APP,不会没关系,我推荐你使用显卡服务器运行安卓模拟器...

很多人都想用电脑端运行手机APP&#xff0c;但是又不知道怎么操作。纵横170yun小编推荐大家使用显卡服务器&#xff0c;在显卡服务器上运行安卓模拟器。让你轻轻松松在电脑端运行手机APP&#xff0c;甚至还可以多开噢 。如果你的电脑没有显卡&#xff0c;也没有关系&#xff0c…