因为项目是教育类的,因此会遇到选择题,单选多选不定项之类的,而从后台传过来的答案是1,2,4,8之类的数字,用来对应ABCD,采用数值相加来解决多选问题,好比后台传来的值是8,就是对应选项D,而穿过15,就对应1+2+4+8,也就是ABCD四个选项,起初我觉得只有ABCD四个选项,因此就只写了四个选项的转换,后来发现选项不止四个,甚至不定项的选项个数也是不肯定的,可是上限是26个,因此以前的方法不能用了,后来就改了一种写法数组
function xyz(val, len) { //值 选项数 let s = "" for (let i = len; i >= 0; i--) { let t = Math.pow(2, i); if (val - t >= 0) { val = val - t; s = s + String.fromCharCode(i + 65); } } //将选项排序 return s.split('').sort().join(''); };
其中val是须要进行转换的数字,好比15,1024等等,len是选项的个数,后面的String.fromCharCode是将数根据acsll码转成大写字母,后来感受传入两个参数在某方面不便,因此直接改为了一个参数代码以下函数
function xyz(val) { //值 let s = "" for (let i = 25; i >= 0; i--) { let t = Math.pow(2, i); if (val - t >= 0) { val = val - t; s = s + String.fromCharCode(i + 65); } } return s.split('').sort().join(''); }
这个只须要传入一个参数,由于字母只有26个,因此直接限制的上限,可是缺点就是会比上一种性能低,虽然我感受不出来,这个函数应该显示传入的val的大小,低于2^(选项个数)-1;因此当选项比较少时能够限制一下,多的话由于我是从后台获取的数,因此我就没限制,根据实际状况吧。
另外,题目的选项是数组的索引,因此不须要用到这个方法,这个只是选择题的答案,根据索引来显示对应的ABCD能够用这个:性能
function numABC(num) { let abc=num+65; return String.fromCharCode(abc); }
一样也是根据acsll码来转换的额,应当对传入的值进行限制,可是我懒,哈哈。code