首页
学习
活动
专区
圈层
工具
发布

js打乱数组内元素顺序(Fisher–Yates shuffle洗牌算法)

如何将数组内元素顺序打乱呢?这里小shy向大家介绍一种算法。 Fisher–Yates shuffle:洗牌算法。...通俗理解: 先将数组最后一位元素作为参考点,将这个参考点和数组其他位置的元素(使用随机数获得)交换位置(当然也有不改变其位置的情况); 然后将数组倒数第二位元素作为参考点,将这个参考点和数组其他位置的元素...(使用随机数获得)交换位置(当然也有不改变其位置的情况); 然后将数组倒数第三位元素作为参考点,将这个参考点和数组其他位置的元素(使用随机数获得)交换位置(当然也有不改变其位置的情况); 以此类推,直到参考点为数组第一位元素交换完毕之后结束...最终得出一个打乱顺序的数组。 应用场景:随机展示图片、随机音乐播放等等。...let point = len - 1; point >= 0; point--) { index = Math.floor(Math.random() * point); // 交换两个元素的值

2K20

调整数组元素顺序

前言 有一个整数数组,我们想按照特定规则对数组中的元素进行排序,比如:数组中的所有奇数位于数组的前半部分。 本文将带大家实现这个算法,欢迎各位感兴趣的开发者阅读本文。...通过观察后,我们发现在扫描这个数组的时候,如果发现有偶数出现在奇数的前面, 就交换他们的顺序,交换之后就符合要求了。...this.end--; } // begin指向了偶数,end指向了奇数 if (this.begin < this.end) { // 交换两个元素的顺序...这样回答没有问题,确实解决了这个问题,那么如果再改改题目,我们需要把数组中的元素分为两部分,能被3整除的数都在不能被3整除的数前面,应该怎么做?...this.end--; } // begin与end都指向了正确的位置 if (this.begin < this.end) { // 交换两个元素的顺序

1.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    js 实现元素拖拽

    概述 js 实现拖拽,主要使用元素的 onmousedown、onmousemove、onmouseup 三个事件实现。...1、onmousedown:鼠标按下事件 2、onmousemove:鼠标移动事件 3、onmouseup:鼠标抬起事件 实现思路 我们当左键点击时,需要记录当前的鼠标点击位置相对于该元素左上角的x,y...坐标,这里我们使用diffX和diffY来表示 然后我们移动时需要不断计算当前元素距离浏览器左边和上边的距离; 同时给元素进行赋值; 当鼠标抬起时,取消鼠标移动事件和鼠标抬起事件。...id="drag"> window.onload = function () { //获取drag元素...clientX 和 clientY 默认是以元素左上角位置来计算的,这里需要向左向上同时减去鼠标点击的位置差,从而可以保证鼠标始终显示在拖拽元素时的位置

    13.1K30

    js 实现元素拖拽

    用鼠标的位置减去盒子距离画布页面X,Y轴的距离就是鼠标在画布内的位置 e.pageY  获取鼠标Y轴距离页面的距离 e.pageX  获取鼠标X轴距离页面的距离 drag.offsetLeft  获取元素距离画布页面左侧距离...drag.offsetTop  获取元素距离画布页面上侧距离 获取鼠标按下后  移动时的坐标 用移动时的坐标减去 鼠标距离盒子内部的位置然后 重新给当前元素的坐标赋值 当鼠标事件抬起时 将拖拽事件清除...> window.onload = function () { //获取drag元素...let drag = document.getElementById("drag"); // 获取画布元素...clientX 和 clientY 默认是以元素左上角位置来计算的,这里需要向左向上同时减去鼠标点击时的偏移位置差,从而可以保证鼠标始终显示在拖拽元素时的位置

    2.2K00

    原生js添加元素

    今天做页面使用的mui,因为使用mui情况下无法使用jquery,于是在ajax请求完毕添加元素的时候发现自己竟然对原生js添加元素的方法有点模糊了,真是越活越倒退了,赶紧整理一波。...首先最简单的innerHTML,这个不想多说,入门新手喜欢这么用,但他的缺点也很明显:不管你渲染部分还是全部,始终需要替换原先所有的子元素,也就是需要重复渲染,会增加浏览器压力。...接下来就是正题了,js推荐是这样进行元素添加: 1.创建游离元素节点:let div=document.createElement(“div”); 2.给创建元素添加属性:div.setAttribute...className”);注意setAttribute一次只能设置一条属性 3.创建文本节点:let textNode=document.createTextNode(“需要添加的文本”); 4.将文本节点添加到元素节点中...div.appendChild(textNode); 5.加元素节点插入文档:Parent.appendChild(div); over 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    10.9K20

    JS如何替换元素内容

    ,有的是动态的,特别是在一些网页交互的网页特效里,应用比较多,如何简单的替换元素的内容 01 原生JS实现 在原生js中主要通过DOM提供的属性去修改的,遵循js的一个使用规范,获取元素,绑定事件,操作...v-model="input" clearable> 替换元素...input-wrap { display:flex; justify-content: center; margin-bottom: 20px; } 分析 在原生js...当中,innerHTML是DOM元素对象一个非常重要的属性,可以获取元素整个节点的内容,包括标签元素,表示元素的所有内容,包括子元素,文本等 注意要与innerText区分,innerText只可以获取文本节点内容...,如果仅是修改DOM元素节点文本内容,使用innerText也是可以的 而在vue里面,并不是通过操作DOM去实现的,而是操作数据,通过操作数据实现的,与原生js的使用是有差异的

    13.8K20
    领券