1

由于项目是教育类的,所以会遇到选择题,单选多选不定项之类的,而从后台传过来的答案是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码来转换的额,应当对传入的值进行限制,但是我懒,哈哈。


chow
982 声望4 粉丝

莫得感情,莫得钱的杀手