如何从JavaScript数组中获取多个随机唯一元素?

The JavaScript is a very versatile language and it has a function almost everything that you want.

JavaScript是一种非常通用的语言,它几乎具有您想要的所有功能。

Here, we will show you how to generate random unique elements from an array in JavaScript?

在这里,我们将向您展示如何从JavaScript数组中生成随机的唯一元素?

The random() function does this work for you. It is a powerful function that can generate multiple random unique numbers. The random() function generates a float number between o and 1. Including only 1. So, we will use this random number to find random elements of the JavaScript array.

random()函数可以为您完成此工作。 它是一个强大的功能,可以生成多个随机唯一数random()函数生成一个介于o和1之间的浮点数。仅包含1。因此,我们将使用此随机数查找JavaScript数组的随机元素。

JavaScript code to get multiple random unique elements from an array

JavaScript代码从数组中获取多个随机唯一元素

<html>
<body>
<div id="one">
<p>one</p>
</div>
<div id="two">
<p>two</p>
</div>
<script>
function shuffle(a) {
for (let i = a.length - 1; i > 0; i--) {
const j = Math.floor(Math.random() * (i + 1));
[a[i], a[j]] = [a[j], a[i]];
}
return a;
}
var arr = [
"<span class=\"booklink\"><a href=\"/one\">one</a></span>",
"<span class=\"booklink\"><a href=\"/one\">two</a></span>",
"<span class=\"booklink\"><a href=\"/one\">three</a></span>",
"<span class=\"booklink\"><a href=\"/one\">four</a></span>",
"<span class=\"booklink\"><a href=\"/one\">five</a></span>"
]
/* note: the JavaScript that updates the div had to be near the end
* of the body to work (probably just after the div)
*/
shuffle(arr);
document.getElementById("one").innerHTML = arr.slice(0, 3).toString();
</script>
</body>
</html>

Output

输出量

get multiple random unique elements from an array in JavaScript

Explanation:

说明:

This program finds the random number and then uses the index of the array to fetch elements of the array and then displays the content. Here the content is a link with the index number.

该程序找到随机数,然后使用数组的索引来获取数组的元素,然后显示内容。 这里的内容是带有索引号的链接。

翻译自: https://www.includehelp.com/code-snippets/how-to-get-multiple-random-unique-elements-from-an-array-in-javascript.aspx

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/376896.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用SQL语句添加删除修改字段

1.增加字段 alter table docdsp add dspcodechar(200)2.删除字段 ALTER TABLE table_NAME DROP COLUMNcolumn_NAME3.修改字段类型 ALTER TABLE table_name ALTER COLUMNcolumn_name new_data_type4.sp_rename 改名 EXEC sp_rename [dbo].[Table_1].[fi…

通过命令修改wampserver的mysql密码

WAMP安装好后&#xff0c;mysql教程密码是为空的&#xff0c;那么要如何修改呢&#xff1f;其实很简单&#xff0c;通过几条指令就行了&#xff0c;下面我就一步步来操作。 首先&#xff0c;通过WAMP打开mysql控制台。 提示输入密码&#xff0c;因为现在是空&#xff0c;所以直…

DBNull

1、执行ExecuteScalar时&#xff0c;要进行Null判断&#xff0c;因为对Null进行操作会报&#xff1a;NullReferenceException 2、返回DBNull的情况&#xff0c;因为DBNull是用来表示数据库中Null的&#xff0c;所以如果数据中返回null&#xff0c;程序中就是DBNull&#xff0c…

什么是ACID理论(二阶段、三阶段提交、TCC)

目录二阶段提交协议TCC&#xff08;Try-Confirm-Cancel&#xff09;预留成功预留失败三阶段提交协议总结Some questionsreferenceACID理论时对事务特性的抽象和总结&#xff0c;想要实现ACID需要掌握二阶段提交协议以及TCC 这里是有关协议的论文PDF链接&#xff1a; CONCURRENC…

oracle安装后新建数据库实例及配置

ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务 的解决方法 (2011-01-20 13:50:37) 转载▼标签&#xff1a; it 分类&#xff1a; 技术早上同事用PL/SQL连接虚拟机中的Oracle数据库&#xff0c;发现又报了“ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务…

html5游戏开发--动静结合(二)-用地图块拼成大地图 初探lufylegend

一、前言 本次教程将向大家讲解如何用html5将小地图块拼成大地图&#xff0c;以及如何用现有的高级html5游戏开发库件lufylegend.js开发游戏。 首先让我们来了解了解如何用html5实现动画&#xff0c;毕竟“动静结合”是先有动再有静。看了上一章的内容&#xff0c;或许你就有了…

BASE理论(基本可用策略+ 最终一致性实现)

目录实现基本可用的几个策略1、流量削峰&#xff08;不同地区售票时间错峰出售&#xff09;2、延迟响应&#xff0c;异步处理&#xff08;买票排队&#xff0c;基于队列先收到用户买票请求&#xff0c;排队异步处理&#xff0c;延迟响应&#xff09;3、体验降级&#xff08;看到…

一天一道算法题--6.15--卡特兰数

感谢微信平台---一天一道算法题---每天多一点进步- problem: 12个高矮不同的人 排成两排 每排必须是从矮到高排列 而且第二行比对应的第一排的人高 问排列方式有多少种&#xff1f; analyse: 据说 这题 是来自于 阿里巴巴的面试题 果然 很有分量 ~~ 我反正 胡思乱想了好多 没搞…

现有一些开源ESB总线的比較

现有的开源ESB总线中&#xff0c;自从2003年第一个开源总线Mule出现后&#xff0c;如今已经是百花争鸣的景象了。如今我就对现有的各种开源ESB总线根据性能、可扩展性、资料文档完整程度以及整合难易程度等方面展开。 一&#xff0e;CXF CXF的定位不是ESB总线&#xff0c;而是一…

Paxos算法(Basic Paxos 与 Multi-Paxos思想)

目录Basic Paxos三个角色达成共识的方法对于Basic Paxos的总结Multi-Paxos领导者优化 Basic Paxos 执行referencePaxos 算法包含 2 个部分&#xff1a; 1、Basic Paxos &#xff1a; 描述多节点之间如何就某个值达成共识 2、Multi-Paxos &#xff1a; 描述执行多个Basic Paxos实…

vs2012下调试mvc4源代码

当前流行的应该是mvc3才对。然后在研究mvc3的源代码时候&#xff0c;Html这个属性下的扩展方法Partial()都没有。IntelliSense不会提示该方法&#xff0c;找了半天的资料也问了一些博友&#xff0c;没看到好的解决棒法。最后没辙另辟蹊跷&#xff0c;就开始着手研究mvc4的源代码…

JAVA UDP网络编程学习笔记

一、UDP网络编程概述 采用TCP协议通信时&#xff0c;客户端的Socket必须先与服务器建立连接&#xff0c;连接建立成功后&#xff0c;服务器端也会持有客户端连接的Socket&#xff0c;客户端的Socket与服务器端的Socket是对应的&#xff0c;它们构成了两个端点之间的虚拟通信链路…

firefox 插件开发

IDE&#xff0c;你可以尝试下NetBeans foxbeans这个插件。转载于:https://www.cnblogs.com/sode/archive/2013/01/25/2876562.html

13种负载均衡算法

目录前言&#xff08;1&#xff09;轮转调度&#xff08;Round-Robin Scheduling&#xff09;算法&#xff08;2&#xff09;加权轮转调度&#xff08;Weighted Round-Robin Scheduling&#xff09;算法&#xff08;3&#xff09;随机均衡调度&#xff08;Random Scheduling&am…

对于shell脚本参数获取时的一点小技巧

问题如下&#xff1a; 根据脚本参数的个数$#进行一个循环&#xff0c;在依次输出每个参数$1 $2 $3...... 我有一个循环变量i $i 取到这时的i为1&#xff0c;我想使用这个1再去调用$1,也是就是打印出第一个参数 就是$($i)的意思来取到第几个参数&#xff0c;当然$($i)是不好用的…

(转)页游安全攻与防,SWF加密和隐藏密匙

原文链接&#xff1a;http://netsecurity.51cto.com/art/201211/364775.htm 页游&#xff0c;最最核心的就是客户端&#xff08;swf&#xff09;与服务端的游戏通信了。游戏通信产生的封包&#xff0c;内容是否可识别&#xff0c;可篡改&#xff0c;可重放&#xff0c;处理逻辑…

C++自动类型推导 : auto 与 decltype 用法

基本用法与区别 auto 总是推导出“值类型”&#xff0c;绝不会是“引用”,如果有引用&#xff0c;auto会把引用去掉&#xff0c;推导出值类型&#xff1b; auto 可以附加上 const、volatile、*、& 这样的类型修饰符&#xff0c;得到新的类型。 auto x 10L; // auto推导为…

C++智能指针使用指南 part1:基本使用

加粗样式>TOC 智能指针是代理模式的具体应用&#xff0c;它使用 RAII 技术代理了裸指针&#xff0c;能够自动释放内存&#xff0c; 无需程序员干预&#xff0c;所以被称为“智能指针”。 智能指针不是指针&#xff0c;而是一个对象&#xff0c;所以不要对其调用delete&…

AS3.0 BitmapData类介绍

注&#xff1a;文中的Bitmapdata和BMD均为同一意思BitmapData,BMD为其缩写一&#xff0c;概括&#xff1a; Bitmapdata继承Object对象&#xff0c;实现IBitmapDrawable接口&#xff0c;这个接口有什么用&#xff0c;你可以理解为Drawable,能被画。官方介绍是&#xff1a;IBitma…

C++使用JSON的序列化与反序列化

这里使用的json解析工具为JSON for Modern C,使用的话仅需要包含头文件。 获取方式&#xff1a;wget https://github.com/nlohmann/json/releases/download/v3.7.3/json.hpp JSON json的序列化功能和map一样&#xff0c;用关联数组的"[]"来任意添加数据&#xff0c…