广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >javascript如何定义类数组对象
  • 373
分享到

javascript如何定义类数组对象

2024-04-02 19:04:59 373人浏览 安东尼
摘要

这篇文章主要介绍“javascript如何定义类数组对象”,在日常操作中,相信很多人在javascript如何定义类数组对象问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ja

这篇文章主要介绍“javascript如何定义类数组对象”,在日常操作中,相信很多人在javascript如何定义类数组对象问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”javascript如何定义类数组对象”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

javascript定义类数组对象的方法是:1、首先创建一个空对象;2、为对象直接定义数字下标的属性;3、关键点,为对象设置length属性和splice属性为数字和函数。

教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

js中类数组对象很多,概念简单的讲就是看上去像数组,又不是数组,可以使用数字下标方式访问又没有数组方法。

例: arguments , nodeList , htmlCollection , Jquery

类数组对象特性

1、拥有 length 属性

var a=document.getElementsByTagName("p");
a.__proto__;// HTMLCollection {} 属于类数组对象a.length;//62

2、可以使用数字下标的方式访问对象

a[0];//<p class="aspNetHidden">…</p>

3、不能使用数组原型的方法(如 slice , pop 等)

a.slice;//undefined Error!
a.pop;//undefined Error!

4、使用 instanceof 操作不属于 Array

[] instanceof Array;//true
a instanceof Array;//false

5、可以转换为真数组对象

var arr = Array.prototype.slice.call(a);
arr instanceof Array;//true

PS:注意在IE8下部分对象无法使用slice方法转换为真数组对象。

建议使用jquery提供的 $.makeArray() 方法转换类数组对象

6、通常可定义有其他自定义属性

a.item;//function item() { [native code] }

类数组对象优点

关于优点我相信不用太多描述,可以让js和其他后台语言拥有相同的操作方式。

C#的某些list集合,可以使用数字下标 list[0] 来访问或是使用字符串名称 list['name'] 来访问同一对象

同时还拥有各种自定义方法,自定义属性,看jquery对象的优雅的访问方式即可知是如此美妙的对象。

如何手动创建类数组对象

回归主题,如何手动创建类数组对象。

1、首先创建一个空对象

var array_like = {};//创建一个空对象

2、为对象直接定义数字下标的属性,这在其他语言里是绝对不允许的,对象属性不能使用数字开头,但JS里是可以的,甚至使用中文都可以

array_like[ 0 ] = "test 0";
array_like[ 1 ] = "test 1";
array_like[ 2 ] = "test 2";
array_like[ 3 ] = "test 3";

3、关键点,为对象设置length属性和splice属性为数字和函数

//关键点
array_like.length = 4;//为对象设置length属性
array_like.splice = [].splice;//同时设置splice属性为一个函数

PS:设定splice属性其实是为了欺骗浏览器的控制台,另其显示出数组的模样,可以参考这里

4、测试

//设定自定义属性
array_like.test0=array_like[0];
array_like.test1=array_like[1];
//直接输出
console.log( array_like );//['test 0','test 1'...]
//类型
console.log( $.type( array_like ) );//"object"
//数字下标访问
console.log( array_like[ 0 ] );//"test 0"
//自定义属性访问
array_like.test0;//"test 0"
//不是数组对象
array_like instanceof Array;//false
//转换为真数组对象
var Arr=Array.prototype.slice.call(array_like);
Arr instanceof Array;//true

5、全部代码:

var array_like = {};

array_like[ 0 ] = "test 0";
array_like[ 1 ] = "test 1";
array_like[ 2 ] = "test 2";
array_like[ 3 ] = "test 3";

array_like.length = 4;
array_like.splice = [].splice;

console.log( array_like );
console.log( $.type( array_like ) );
console.log( array_like[ 2 ] );

到此,关于“javascript如何定义类数组对象”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: javascript如何定义类数组对象

本文链接: https://www.lsjlt.com/news/75241.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • javascript如何定义类数组对象
    这篇文章主要介绍“javascript如何定义类数组对象”,在日常操作中,相信很多人在javascript如何定义类数组对象问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ja...
    99+
    2022-10-19
  • JavaScript如何定义对象数组
    本篇内容介绍了“JavaScript如何定义对象数组”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!数组对象用来在单独的变量名中存储一系列的值...
    99+
    2023-06-20
  • JavaScript定义对象数组的方法
    这篇文章主要介绍“JavaScript定义对象数组的方法”,在日常操作中,相信很多人在JavaScript定义对象数组的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Ja...
    99+
    2022-10-19
  • JavaScript怎么定义对象和数组
    这篇文章主要介绍“JavaScript怎么定义对象和数组”,在日常操作中,相信很多人在JavaScript怎么定义对象和数组问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Ja...
    99+
    2022-10-19
  • vue如何定义数组对象
    在vue中定义数组对象的方法:1.新建vue.js项目;2使用personQueryList方法定义数组对象;具体步骤如下:首先,在vue-cli中创建一个vue.js项目;vue create project-namevue.js项目创建...
    99+
    2022-10-06
  • 如何定义javascript数组
    这篇文章将为大家详细讲解有关如何定义javascript数组,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端...
    99+
    2023-06-14
  • 如何将JavaScript对象转成jQuery对象数组对象
    JavaScript 是一种高级的动态编程语言,非常流行。它使得网页在不需要刷新页面的情况下变得更加动态和交互性。然而,当 JavaScript 开发变得越来越复杂,常常需要处理大量的 HTML 元素,这时候就需要用到 jQuery。jQu...
    99+
    2023-05-14
  • JavaScript类数组和可迭代对象如何实现
    本篇内容介绍了“JavaScript类数组和可迭代对象如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2022-10-19
  • javascript中数组如何定义
    这篇文章将为大家详细讲解有关javascript中数组如何定义,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。数组是一组数据的集合,js中,数组里面的数据是可以不同类型的定...
    99+
    2022-10-19
  • es6如何将类数组对象转数组
    今天小编给大家分享一下es6如何将类数组对象转数组的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。转换方法:1、使用“for ...
    99+
    2023-07-04
  • Java对象数组定义与用法详解
    Java对象数组是一种用于存储多个相同类型的对象的数据结构。它可以按照一定的顺序存储和访问对象,并且可以根据需要进行动态调整大小。要定义一个对象数组,可以使用以下语法:```ClassName[] arrayName = new Cla...
    99+
    2023-08-09
    Java
  • jquery如何定义对象
    在jquery中定义对象的方法:1.新建html项目,引入jquery;2.使用{}定义对象;3.使用eval方法为对象添加属性;具体步骤如下:首先,新建一个html项目,并在项目中引入jquery;<script type=&quo...
    99+
    2022-10-12
  • php如何定义对象
    在php中定义对象的方法通过变量定义对象$clsName = 'Person';$obj2 = new $clsName();echo '类名:'....
    99+
    2022-10-21
  • javascript如何获取对象数组
    javascript中获取对象数组的方法:可以使用“getElementsByTagName”方法获取对象数组;语法格式为:“document.getElementsByTagname('li') ”,这里“li”...
    99+
    2022-10-07
  • JavaScript如何定义数据类型
    这篇文章主要介绍“JavaScript如何定义数据类型”,在日常操作中,相信很多人在JavaScript如何定义数据类型问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java...
    99+
    2022-10-19
  • javascript如何定义类
    这篇文章将为大家详细讲解有关javascript如何定义类,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 JavaScript定义类的三个方法...
    99+
    2022-10-19
  • 如何在JavaScript中定义数组
    如何在JavaScript中定义数组?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。JavaScript有什么特点1、js属于一种解释性脚本语言;2、在绝大多数浏览器的支持下,j...
    99+
    2023-06-14
  • java抽象类如何定义
    Java中定义抽象类需要使用关键字"abstract"。抽象类不能被实例化,只能作为其他类的父类,供其他类继承使用。抽象类的定义方式...
    99+
    2023-10-20
    java
  • ADO.NET如何自定义对象
    这篇文章主要讲解了“ADO.NET如何自定义对象”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ADO.NET如何自定义对象”吧!ADO.NET实体框架提供了相应的工具,以便根据 实体数据模型...
    99+
    2023-06-17
  • jquery如何定义json对象
    在jquery中定义json对象的方法:1.新建html项目,引入jquery;2.使用json字符串定义json对象;3.使用JSON.parse方法解析json对象;具体步骤如下:首先,新建一个html项目,并在项目中引入jquery;...
    99+
    2022-10-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作