随机留言的实现

问题背景

对于一个给定的数组,如何随机获得它的元素

解决方案

随机获取数组一个元素

language 复制代码
var items = ['1','2','4','5','6','7','8','9','10'];
var item = items[Math.floor(Math.random()*items.length)];

解释:

Math.random()返回0到1之间的一个伪随机数,可能等于0,但是一定小于1

Math.floor方法返回小于参数值的最大整数(地板值)

结合起来:

随机获取一个0-1之间的小数, 然后乘以自身长度, 一定是一个大于等于0 小于自身长度的一个数. 如上面 长度为10, 则获取的一个随机数就为0-10之间的一个数[数组的下标].

最后根据下标获取数组元素值即可

随机获取几个元素

javascript 复制代码
function getRandomArrayElements(arr, count) {
    var shuffled = arr.slice(0), i = arr.length, min = i - count, temp, index;  //只是声明变量的方式, 也可以分开写
    while (i-- > min) {
        //console.log(i);
        index = Math.floor((i + 1) * Math.random()); //这里的+1 是因为上面i--的操作  所以要加回来
        temp = shuffled[index];  //即值交换
        shuffled[index] = shuffled[i]; 
        shuffled[i] = temp;
        //console.log(shuffled);
    }
    return shuffled.slice(min);
}


var items = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10'];
console.log( getRandomArrayElements(items, 4) );

随机一个留言

javascript 复制代码
<script>
  export default{
    data () {
      return {
        redEnvelope: {
          rewardMessage: '乐知乐享,同心共济',
          rewardNum: null,
          rewardPoint: null
        },
      }
    },
    methods: {
      randomMessage(){
        let _message = this.redEnvelope.rewardMessage //默认显示乐知乐享,同心共济
        let messageList = ['乐知乐享,同心共济', '大吉大利,永不宕机', '一起分享,共同学习', '节日快乐', '欢迎来到墨天轮']
        let _newMessage = messageList[Math.floor((Math.random()*messageList.length))]
        if(_message == _newMessage) _newMessage = messageList[Math.floor((Math.random()*messageList.length))] //如果随机的留言和上次的一样,再次随机一个留言
        this.redEnvelope.message = _newMessage
      },
    }
  }
</script>
相关推荐
fie88895 分钟前
MATLAB中LASSO方法的特征矩阵优化与特征选择实现
开发语言·matlab·矩阵
LilySesy10 分钟前
【SAP-MOM项目】二、接口对接(中)
开发语言·python·pandas·restful·sap·abap
零度@12 分钟前
专为 Java 开发者 整理的《Python编程:从入门到实践》前8章核心内容
java·开发语言·windows·python
nbsaas-boot17 分钟前
架构设计怎么做:一套可复用、可落地的方法论
java·开发语言·微服务
骆驼爱记录17 分钟前
Word表格题注自动设置全攻略
开发语言·c#·自动化·word·excel·wps·新人首发
wbs_scy19 分钟前
C++:智能指针完全指南(原理、用法与避坑实战,从 RAII 到循环引用)
开发语言·c++·算法
无人装备硬件开发爱好者21 分钟前
Python + Blender 5.0 几何节点全栈实战教程1
开发语言·python·blender
u01092727121 分钟前
C++中的对象池模式
开发语言·c++·算法
武超杰22 分钟前
深入理解JDBC:Java数据库连接的核心技术与实践
java·开发语言·数据库·jdbc
80530单词突击赢24 分钟前
MPPI算法:ROS下的智能控制实战
开发语言·python