javaScript(十四) TypedArray,学生党必看

示例:

var f64a=new Float64Array(8); f64a.forEach(x => console.log(x)); //输出:0 0 0 0 0 0 0 0

第三种方法是

new TypedArray(类型化数组)

当传入一个类型化数组作为参数时,那么这个类型化数组将被复制到一个新的类型化数组。

const x=new Int8Array([1,1]);

const y=new Int8Array(x);

x[0]=2;

console.log(x[0]) //输出2

console.log(y[0]) //输出1,不会随着X的改变而改变

这边y虽然是x复制过来的,但是y不会随着x修改,如果要求同步,那么,参数x得是x.buffer,意思是代表指向同一段地址

const x=new Int8Array([1,1]);

var z=new Int8Array(x.buffer);

x[0]=4;

console.log(x[0]) //输出4

console.log(z[0]) //输出4

第四种方式是:

new TypedArray(类型化数组),但是直接传入数组

const a=new Int8Array([1,2,3,4])

TypedArray方法

TypedArray.form(类数组):使用类数组或迭代对象创建一个新的类型化数组

TypedArray.of(元素0,元素1,元素2…元素n):通过可变数量的参数创建新的类型化数组

TypedArray原型

TypedArray.prototype.constructor:返回创建示例原型的构造函数

TypedArray.prototype.buffer:返回被格式化数组引用的ArrayBuffer,创建时已被固化,因此是只读的

TypedArray.prototype.byteLength:返回从ArrayBuffer读取的字节长度,创建时已被固话,因此是只读的

TypedArray.prototype.byteOffset:返回从ArrayBuffer读取时的字节偏移量,创建时已被固话,因此是只读的

TypedArray.prototype.lenghth:返回在类型化数组中的元素数量,创建时已被固化,因此是只读

TypedArray原型方法

普通数组的原型方法,TypedArray基本都有,例如every(),fill()等等

但是:

TypedArray没有concat()方法

而且下列是独有的:

**TypedArray.prototype.set()**代表:用于将数组(普通数组或TypeArray数组)中一段内容完全复制到另一段内存

**TypeArray.prototype.subArray()**代表:对于TypeArray数组的一部分,在建立一个新的视图

TypedArray和数组的区别

TypedArray数组
数组成员均为同一个类型可以是任意类型
数组成员是连续的,不会有空位非连续
数组的成员默认值均为0默认为空
视图,不存储数据存储数据

实际应用

传统意义上服务通过AJAX只能返回文本数据,responseType默认是一个text,但是在xhr中,可以设定为一个二进制数据,只需要将responseType设置成arraybuffer

var xhr=new XMLHttpRequest();

xhr.open(“GET”,“/myfile.png”,true);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

前端CSS面试题文档,JavaScript面试题文档,Vue面试题文档,大厂面试题文档,需要的读者可以戳这里免费领取!

前端CSS面试题文档,JavaScript面试题文档,Vue面试题文档,大厂面试题文档,需要的读者可以戳这里免费领取!

[外链图片转存中…(img-avrzFTFb-1712160182845)]

[外链图片转存中…(img-ry0Xe6JY-1712160182845)]

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值