阿里在线前端笔试题

本人大三,非985,211。

参加了2015年暑假实习校园招聘,好吧,其实就看看题目长什么样字、废话不多说,上题。

一共13题,6个选择,1题是github地址或博客微博地址,6个大题。

选择题第一题:

var arr = [1,2,3,4,5];
arr.splice(1,2,3,4,5);
arr?

考察数组splice的用法。

后面几个选择题忘了(别打脸),选择题都不是很难。

 

大题:

1.考查css的基本知识,给出html基本代码。写css代码, 每个div是一个盒子模型。中间文字水平垂直居中,三个盒子水平排列。(比较基础,代码就不上了)

2.多维数组转一位数组:原题:[1,[2,3]] ==》 [1,2,3]

var arr = [1,[[4,5,6],2,[[[7,8,9]]],3]]; //转成一位数组:[1, 4, 5, 6, 2, 7, 8, 9, 3]
function f(arr){
    if(Object.prototype.toString.call(arr) != '[object Array]')  //判断arr是不是数组
        return;
    var newArr = [];
    function fn(arr){ 
        for (var i = 0; i < arr.length; i++) {//遍历数组
            if(arr[i].length){//判断是不是多维数组
                fn(arr[i]);    //递归调用
            }else{
                newArr.push(arr[i]);
            }
        }
    }
    fn(arr);
    return newArr;
}
console.log(f(arr));

当时在做试卷的时候 没有考虑多维数组,只片面的为了解题,没有用递归。

更优做法:感谢 @ double Net

[1,[[4,5,6],2,[[[7,8,9]]],3]].toString().split(",")

 

3.数字类型转千分位表示

var num = 123456789.9; //结果转成千分位表示 123,456,789.9
function f(num){
    if(typeof num != 'number')
        return;
    num += '';
    if(num.indexOf('.')!=-1){ //判断是否存在小数
        return fn(num.split('.')[0])+'.'+num.split('.')[1];
    }else{
        return fn(num);
    }
    function fn(newNum){
        var str = '';
        var l = newNum.length;
        while(l>3){
            str = ','+newNum.substring(l-3,l) + str;
            l = l-3;
        }
        str = newNum.substring(0,l) + str;
        return str;
    }
}
console.log(f(num));

4.解析url:var str = 'http://s.weibo.com/weibo/Aralic?topnav=1&wvr=6'获得参数名和参数值:

(以前做过类似的题目,解析url一系列的值,阿里这题感觉稍微简单一点)

在《javascript语言精粹》一书中看到使用正则 表达式 直接解析url,不过略难

 

function f(url){
    var l = url.indexOf('?');
    if(l!=-1){
        var obj = {};
        var arr = url.substring(l+1,url.length).split('&');
        for(var i = 0; i<arr.length; i++){
            obj[arr[i].split('=')[0]] = arr[i].split('=')[1];
        }
        return obj;
    }
}
console.log(f('http://s.weibo.com/weibo/Aralic?topnav=1&wvr=6'))

有幸看到的园子大牛帮忙给点意见,不是专门学计算机的,算法比较差。

我的github博客:http://aralic.github.io/  

对markdown更友好一点,排版也舒服一些。

虽然是做前端的,但是对自己博客的不知道为什么不想自己设计自定义样式。

posted @ 2015-04-06 23:20  Aralic  阅读(3662)  评论(17编辑  收藏  举报