js 如何使用fill填充数组的某部分内容

fill 方法会直接修改原数组,若要避免修改原数组,应先使用 slice 方法创建副本再调用 fill;当填充对象时,由于填充的是引用,修改其中一个元素会影响所有元素,因此需注意使用独立对象;fill 可结合 array.from 生成特定数组,且能填充稀疏数组的空槽,但不支持老浏览器时需引入 polyfill。

js 如何使用fill填充数组的某部分内容

fill

方法,可以直接修改原数组,把数组的一部分或者全部替换成指定的值。这玩意儿用起来挺方便,但也有点小坑,一会儿细说。

解决方案

fill

的基本用法是

array.fill(value, start, end)

value

是你要填充的值,

start

是起始索引(包含),

end

是结束索引(不包含)。如果

start

end

都省略了,那就把整个数组都填满。

举个例子:

let arr = [1, 2, 3, 4, 5];arr.fill(0, 2, 4); // 从索引2开始,到索引4之前(不包括4)console.log(arr); // 输出: [1, 2, 0, 0, 5]let arr2 = [1, 2, 3, 4, 5];arr2.fill(9); // 全部填充console.log(arr2); // 输出: [9, 9, 9, 9, 9]

需要注意的是,

fill

是直接修改原数组,而不是返回一个新的数组。

如果

value

是一个对象,那可就有点意思了。

fill

填充的是对象的引用,而不是复制对象。这意味着,如果你修改了其中一个填充的对象,所有填充的对象都会被修改。

let obj = { a: 1 };let arr3 = new Array(3).fill(obj);console.log(arr3); // 输出: [{a: 1}, {a: 1}, {a: 1}]arr3[0].a = 2;console.log(arr3); // 输出: [{a: 2}, {a: 2}, {a: 2}]  注意这里都变了!

看到了吧,

arr3[0].a

修改了,整个数组里的对象都跟着变了。这是因为它们都指向同一个对象。

如何避免

fill

修改原数组?

其实很简单,用

slice

复制一份再

fill

就行了。

let arr4 = [1, 2, 3, 4, 5];let newArr = arr4.slice().fill(0, 2, 4);console.log(arr4); // 输出: [1, 2, 3, 4, 5] (原数组没变)console.log(newArr); // 输出: [1, 2, 0, 0, 5] (新数组被修改)

这样,

newArr

就是一个全新的数组,修改它不会影响到

arr4

fill

方法还可以用来初始化数组,特别是当数组的长度是动态确定的时候。

let len = 10;let arr5 = new Array(len).fill(null); // 初始化一个长度为10的数组,所有元素都是nullconsole.log(arr5); // 输出: [null, null, null, null, null, null, null, null, null, null]
fill

还有一个比较少见的用法,就是配合

Array.from

来生成一些特殊数组。

let arr6 = Array.from({length: 5}, (_, i) => i + 1); // 生成 [1, 2, 3, 4, 5]console.log(arr6);let arr7 = Array.from({length: 5}).fill(0); // 生成 [0, 0, 0, 0, 0], 注意这里先fill再from效果不一样console.log(arr7);
Array.from

允许你从一个类数组对象或者可迭代对象创建一个新的数组实例。

fill

的兼容性怎么样?

fill

是 ES6 引入的,所以老版本的浏览器可能不支持。如果需要兼容老版本浏览器,可以使用 polyfill。

if (!Array.prototype.fill) {  Array.prototype.fill = function(value) {    // Steps 1-2.    if (this == null) {      throw new TypeError('this is null or not defined');    }    var O = Object(this);    // Steps 3-5.    var len = O.length >>> 0;    // Steps 6-7.    var start = arguments[1];    var relativeStart = start >> 0;    // Step 8.    var k = relativeStart > 0;    // Step 11.    var final = relativeEnd < 0 ?      Math.max(len + relativeEnd, 0) :      Math.min(relativeEnd, len);    // Step 12.    while (k < final) {      O[k] = value;      k++;    }    // Step 13.    return O;  };}

这个 polyfill 可以在 MDN 上找到。

fill

配合

map

使用有什么要注意的?

fill

map

都是数组操作中常用的方法,但是它们的行为有所不同。

fill

直接修改原数组,而

map

返回一个新的数组。

let arr8 = [1, 2, 3];arr8.fill(0).map(x => x + 1); // 看起来像要把数组填充为0,然后每个元素加1console.log(arr8); // 输出: [0, 0, 0]

上面的代码并没有达到预期的效果,因为

fill

先把数组变成了

[0, 0, 0]

,然后

map

对这个数组进行操作,但是

map

的返回值并没有赋值给

arr8

如果想要达到预期的效果,可以先

map

fill

,或者使用

Array.from

let arr9 = [1, 2, 3].map(x => x + 1);console.log(arr9); // 输出: [2, 3, 4]let arr10 = Array.from([1, 2, 3], x => x + 1);console.log(arr10); // 输出: [2, 3, 4]

什么时候应该使用

fill

,什么时候应该使用循环?

一般来说,如果需要批量设置数组的某个范围内的值,

fill

是一个不错的选择,代码简洁易懂。如果需要根据索引或者其他条件来设置数组的值,循环可能更灵活。

fill

在处理稀疏数组时的行为是什么?

稀疏数组是指数组中包含空槽(hole)的数组。

fill

会将稀疏数组中的空槽填充为指定的值。

let arr11 = new Array(5); // 创建一个长度为5的稀疏数组console.log(arr11); // 输出: [  ]arr11.fill(0);console.log(arr11); // 输出: [ 0, 0, 0, 0, 0 ]
fill

会将稀疏数组中的所有空槽都填充为 0。

总结一下,

fill

是一个很方便的数组填充方法,但是需要注意它的行为,特别是当填充的值是对象的时候。要避免修改原数组,可以使用

slice

复制一份再

fill

。 在某些情况下,

fill

配合

Array.from

可以生成一些特殊的数组。

以上就是js 如何使用fill填充数组的某部分内容的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1517332.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 10:42:03
下一篇 2025年12月20日 10:42:13

相关推荐

  • 深入理解CSS框架与JS之间的关系

    深入理解CSS框架与JS之间的关系 在现代web开发中,CSS框架和JavaScript (JS) 是两个常用的工具。CSS框架通过提供一系列样式和布局选项,可以帮助我们快速构建美观的网页。而JS则提供了一套功能强大的脚本语言,可以为网页添加交互和动态效果。本文将深入探讨CSS框架和JS之间的关系,…

    2025年12月24日
    000
  • HTML+CSS+JS实现雪花飘扬(代码分享)

    使用html+css+js如何实现下雪特效?下面本篇文章给大家分享一个html+css+js实现雪花飘扬的示例,希望对大家有所帮助。 很多南方的小伙伴可能没怎么见过或者从来没见过下雪,今天我给大家带来一个小Demo,模拟了下雪场景,首先让我们看一下运行效果 可以点击看看在线运行:http://hai…

    2025年12月24日 好文分享
    500
  • 10款好看且实用的文字动画特效,让你的页面更吸引人!

    图片和文字是网页不可缺少的组成部分,图片运用得当可以让网页变得生动,但普通的文字不行。那么就可以给文字添加一些样式,实现一下好看的文字效果,让页面变得更交互,更吸引人。下面创想鸟就来给大家分享10款文字动画特效,好看且实用,快来收藏吧! 1、网页玻璃文字动画特效 模板简介:使用css3制作网页渐变底…

    2025年12月24日 好文分享
    000
  • tp5如何引入css文件

    tp5引入css文件的方法:1、将css文件放在public目录下的static文件里即可;2、在页面引入中写上“”语句即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 其实很简单,只需要将css,js,image文件放在这个目录下即可 页…

    2025年12月24日
    000
  • 聊聊CSS 与 JS 是如何阻塞 DOM 解析和渲染的

    本篇文章给大家介绍一下css和js阻塞 dom 解析和渲染的原理。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 hello~各位亲爱的看官老爷们大家好。估计大家都听过,尽量将CSS放头部,JS放底部,这样可以提高页面的性能。然而,为什么呢?大家有考虑过么?很长一段时间,我都是知其…

    2025年12月24日
    200
  • js如何修改css样式

    js修改css样式的方法:1、使用【obj.className】来修改样式表的类名;2、使用【obj.style.cssTest】来修改嵌入式的css;3、使用【obj.className】来修改样式表的类名;4、使用更改外联的css。 本教程操作环境:windows7系统、css3版,DELL G…

    2025年12月24日
    000
  • 如何使用纯CSS、JS实现图片轮播效果

    本篇文章给大家详细介绍一下使用纯css、js实现图片轮播效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 .carousel {width: 648px;height: 400px;margin: 0 auto;text-align: center;position: a…

    2025年12月24日
    000
  • js如何修改css

    js修改css的方法:1、使用【obj.style.cssTest】来修改嵌入式的css;2、使用【bj.className】来修改样式表的类名;3、使用更改外联的css文件,从而改变元素的css。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 js修改css的方法: 方法…

    2025年12月24日
    000
  • js如何改变css样式

    js改变css样式的方法:1、使用cssText方法;2、使用【setProperty()】方法;3、使用css属性对应的style属性。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 js改变css样式的方法: 第一种:用cssText div.style.cssText…

    2025年12月24日
    000
  • 为什么css放上面js放下面

    css放上面js放下面的原因:1、在加载html生成DOM tree的时候,可以同时对DOM tree进行渲染,这样可以防止闪跳,白屏或者布局混乱;2、javascript加载后会立即执行,同时会阻塞后面的资源加载。 本文操作环境:Windows7系统、HTML5&&CSS3版,DE…

    2025年12月24日
    000
  • css中的浏览器私有化前缀有哪些

    css中的浏览器私有化前缀有:1、谷歌浏览器和苹果浏览器【-webkit-】;2、火狐浏览器【-moz-】;3、IE浏览器【-ms-】;4、欧朋浏览器【-o-】。 浏览器私有化前缀有如下几个: (学习视频分享:css视频教程) -webkit-:谷歌 苹果 background:-webkit-li…

    2025年12月24日
    300
  • 推荐六款移动端 UI 框架

    作为一个前端人员来说,总结几款相对来说不错的用于移动端开发的UI框架是非常必要的,以下几种移动端UI框架就能基本满足工作中开发需要,根据项目需求,选用合适的框架搭建项目,更能容易提高开发效率。 一、MUI         最接近原生APP体验的高性能前端框架,追求性能体验,是我们开始启动MUI项目的…

    2025年12月24日
    000
  • 如何利用css改变浏览器滚动条样式

    注意:该方法只适用于 -webkit- 内核浏览器 滚动条外观由两部分组成: 1、滚动条整体滑轨 2、滚动条滑轨内滑块 在CSS中滚动条由3部分组成 立即学习“前端免费学习笔记(深入)”; name::-webkit-scrollbar //滚动条整体样式name::-webkit-scrollba…

    2025年12月24日
    000
  • css如何解决不同浏览器下文本兼容的问题

    目标: css实现不同浏览器下兼容文本两端对齐。 在 form 表单的前端布局中,我们经常需要将文本框的提示文本两端对齐,例如: 解决过程: 立即学习“前端免费学习笔记(深入)”; 1、首先想到是能不能直接靠 css 解决问题 css .test-justify { text-align: just…

    2025年12月24日 好文分享
    200
  • css如何实现图片的旋转展示效果(代码示例)

    本篇文章给大家带来内容是通过代码示例介绍使用css+js实现图片的旋转展示,制作一个手动操作的“无限”照片轮播图。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 下面我们就开始介绍如何实现效果。 1、构建图像轮播框架 首先是HTML。它有点难以阅读,因为我们删除了元素之间的任何空格…

    2025年12月24日
    000
  • css3+js实现烟花绽放的动画效果(代码示例)

    本篇文章给大家介绍通过js+css3的transforms属性和keyframes属性来实现烟花绽放的动画效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来看看效果: 动画的实现原理: 动画使用了两个关键帧(keyframes): 一个是烟花筒上升的轨迹,另一个…

    2025年12月24日
    000
  • css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)

    本篇文章给大家带来的内容是介绍css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在之前的文章【css如何实现幻灯片效果?幻灯片的实现方法】中介绍了实现淡入淡出幻灯片的实现方法,本篇文章就在其基础上去解释如何在幻灯片上…

    2025年12月24日
    000
  • css+js如何实现简单的动态进度条效果?(代码实例)

    css+js如何实现简单的动态进度条?本篇文章就给大家用css+js制作一个简单的动态进度条效果,并将页面动态进度条滚动加载的代码分享给大家,感兴趣的小伙伴可以参考借鉴一下,希望对你们有所帮助。 我们要知道,这里主要使用了css3的animation动画属性,首先将进度条设置为一个初始宽度为0,背景…

    2025年12月24日
    000
  • 手写CSS+js实现radio单选按钮

    本文给大家介绍手写css+js实现radio单选按钮,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 有的时候我们需要用长得漂亮一点的单选按钮,那么,就要抛弃原有的自己来写,下面就是我实现的 你丑你先你才丑你先你更丑你先 .radio{display: flex;align-ite…

    2025年12月24日
    000
  • css3+js绘制动态时钟(附代码)

    本章给大家介绍如何使用css3与js实现动态时钟效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 先看看效果图: 首先,思考了一下页面的布局,大致需要4层div,最底层是一个表盘的背景图,然后其余3层分别是时针,分针,秒针的图层. html代码如下: 变量名是随便起的,不要介意;…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信