<script>
// 第一种key - 随机获取10位不同的数字 并且数字不能小于10 不能大于100 并且排序
let arr = [];
for(let i = 0; i < 30; i++) {
let num = (`${Math.random() * 100}`).split('.')[0];
num = `${(num - i) < 10 ? 10 + i : num - i }`;
if(arr.indexOf(num) === -1)arr.push(num);
};
arr.splice(10);
arr = arr.sort((a,b) => a - b).join('-',',');
console.log('字符唯一性A-arr-循环: ',arr);
// 字符唯一性A-arr-循环: 10-13-16-46-64-66-70-72-82-96
// 第二种key - 随机获取10位不同的数字 并且数字不能小于10 不能大于100 并且排序
/**
* @param {
* leave: 默认返回拼接字符 12-14-15...
* calculation: 保留长度多少位 默认 10位
* size: 数字不小于多少位 默认 10位
* volume :数字单位以多少起步 默认 100
* }
*/
function sumNum(leave = true,calculation = 10,size = 10,volume = 100){
let index = 0,arrNum = [];
function sumArr(){
let num = (`${Math.random() * volume}`).split('.')[0];
num = `${(num - index) < size ? (size + index) : (num - index)}`;
if(arrNum.indexOf(num) === -1)arrNum.push(num);
if(arrNum.length === calculation)return arrNum;
index++;
sumArr();
};
sumArr();
return arrNum = leave ? arrNum.sort((a,b) => a - b).join('-',',') : arrNum.sort((a,b) => a - b);
};
console.log('字符唯一性B-sumNum-递归: ',sumNum(true,10));
// 字符唯一性B-sumNum-递归: 16-18-22-25-40-49-52-62-63-84
</script>
以上提供了两种方式:
第一种采用循环,进行选取随机数。为确保该循环项的数字不能小于10所以要做一层处理,通过用indexOf来判断该循环项的数字在数组是否是唯一性的,然后将该数字push到数组里。最后通过数组长度判断 === 10。
第二种采用递归,借住第一种思路进行代码进一步提升。第二种相对于第一种代码灵活了很多。
不仅可以获取到10位组成的数据,甚至可控性较为灵活还可以获取更多位数字,当然还可以通过true或者false来决定返还是一个数组还是拼接好的字符。