首页
学习
活动
专区
工具
TVP
发布
您找到你想要的搜索结果了吗?
是的
没有找到

JS数组at函数(获取最后一个元素的方法)介绍

本文介绍js中数组的at函数,属于比较简单的知识普及性文章,难度不大。 0x00 首先,我们可以思考如下一个问题,如果要获取一个数组的最后一个元素(这是很常用的操作),我们应该怎么做?...当然除了这种方式之外,还有其他的方式,比如: let last = array.slice(-1)[0] 先通过slice获取后面一个元素的数组,然后通过下标0获取最后一个元素。...在比如通过pop获取最后一个元素: let last = array.pop() 但是 通过pop的方式会改变数组本身,所以一般不建议用。 0x01 无论试用上面那种方式,都感觉很繁琐。...这就让人羡慕python里面的数组操作,可以通过负索引的方式获取最后一个元素,代码如下: last = array[-1] js里面不支持负索引的方式。...不过es6新增了一个at方法,可以获取数组的指定索引的元素,并且支持负索引。负索引从后往前计算,-1表示最后一个,-2 表示倒数第二个,依此类推。 因此试用此方法获取最后一个元素会变得简单很多。

4.4K30

对象最后一次救赎

答案是:判断算法 引用计数算法 虚拟机会给每一个对象设置一个计数器,每当对象被引用的时候计数器就会+1,当引用断掉的时候计数器-1。当引用计数器的值为0时则表示该对象没有被引用到,可以被回收。 ?...在此,对象A--对象B--对象C,都有被引用,而对象D没有被引用,那么对象D会被回收。...对象最后一次救赎 刚刚我们上面谈到通过可达性算法来判断对象是否已经死亡,其实在可达性分析算法中判定为不可达的对象,也并不一定就会死亡的,要判定一个对象死亡,至少需要两次的标记过程。...如果这个对象被判定为有必要执行finalize()方法,那么该对象将会被放置在一个F-Queue队列中,并在稍后由一条虚拟机自动建立、低调度优先级的Finalizer线程去执行他们的finalize()...这个时候finalize()方法是对象逃脱死亡的最后一次机会,稍后收集器将对F-Queue队列中的对象进行第二次小规模的标记,如果对象要在finalize()方法中拯救自己,只要重新与引用链上的任何一个对象建立关联即可

73020

Js如何创建一个自定义对象

前言 JS中分两种数据类型,一种是基本数据类型,另外就是复杂数据类型,在描述一个事物对象,当比较复杂时,一般可以用数组和对象来存储 在Js中的对象,指的是一系列互相嵌套的键值对,在做web开发时,大多数控件都是以对象或数组的形式来提供给开发人员使用...那如何创建一个对象呢,如何给对象添加属性和方法?...在Js当中有一些方法,如下所示 01 方法1-使用文本字面量形式 这种方法创建对象是比较直接,常见的一种方式,就是使用大括号的方式,可以看做是js对象的本本标识,也就是说,可以通过输出字符串的形式来了解对象有哪些键值对...,它也是JSON形式,用于js的数据存储和传递,给对象添加属性和添加方法 如下代码所示 // 用大括号创建对象的方法,这种方法最常见,使用最频繁 var obj1 = {}; // 使用大括号创建一个内容为空的对象...添加了一个outPut方法,并提供实现了一个alert弹框 alert('给obj1添加了一个outPut方法'); } // 调用对象obj1下面的outPut方法 obj1.outPut()

4.6K20

JS面向对象

JS面向对象 理解对象 数据(数据描述符)属性 数据属性有4个描述内部属性的特性 [[Configurable]] 表示能否通过delete删除此属性,能否修改属性的特性,或能否修改把属性修改为访问器属性...默认为 undefined [[Set]] 一个给属性提供 setter 的方法(给对象属性设置值时调用的函数),如果没有 setter 则为 undefined。...默认为 undefined 创建/修改/获取属性的方法 Object.defineProperty() 功能:方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象。...enumerable: true, value: '张三' }) console.log(obj.name) // 张三 Object.defineProperties() 功能:方法直接在一个对象上定义一个或多个新的属性或修改现有属性...语法: Object.defineProperties(obj, props) obj: 将要被添加属性或修改属性的对象 props: 该对象一个或多个键值对定义了将要为对象添加或修改的属性的具体配置

7.3K20

js对象

课程目标: 1.掌握面向对象的基本操作. 2.掌握构造函数的优化策略. 3.创建对象的方式. 1.创建对象的三种方式: <!....方法名=function() { //输出内容 } let 对象名=new Object(); 对象名.属性; 对象名.方法名(); //第二种方式: let 对象名={}; 对象名.属性名=属性;..."); } console.log(demo===demo); 总结: 构造函数与普通函数的区别: 1.在同一个构造函数创建出来的对象是不一样的...为了使内存地址一样,不占用内存把. 1.调用了同一个普通函数. ? ? 效果: ? 第二奏: <!...1.调用对象是一样的,比如我爱你。他也爱你.是不是爱的是一个人啊。 2.调用构造函数是不一样的,为什么,因为他是类中的。类是一个整体不是个体啊. 效果: ? <!

6.8K10
领券