1248转ABCD

因为项目是教育类的,因此会遇到选择题,单选多选不定项之类的,而从后台传过来的答案是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

相关文章
相关标签/搜索