2014阿里巴巴WEB前端实习生在线笔试题

2014年3月31日晚,我怀着略微忐忑的心情(第一次在线笔试^_^!!)进行了笔试,阿里巴巴的笔试题共有10道,几乎包含了Web前端开发的各个方面,有程序题、有叙述题,时间非常紧张,只完成了大概6道题。下面把遇到的题目跟大家分享一下!

1、

  
      
      
          
      
  
      
        

我是 outer 里面的字

我是 inner 里面的字



 
  
 
  

问:为什么以上两个

标签中的文字颜色都是橙色的?

这里涉及到了CSS中的层叠和特殊性问题,首先按照上下顺序,第一个

元素它的样式很明显是由div.outer p 定义的,所以是橙色。第二个

元素的样式是由样式表中的两个样式同时定义,而且同样是color样式。根据《CSS权威指南》中的介绍,当CSS样式发生层叠时,要通过层叠规则来安排最终元素匹配的样式。CSS2.1的层叠规则中的规定,在没有!important标志时,要按照特殊性排序,如果还不能比较完,就后面覆盖前面。可以参考:CSS层叠规则

2、请实现一个Event类,继承自此类的对象都会拥有两个方法on和trigger,类声明如下,请写出完整代码:

[javascript]  view plain copy
  1. function Event() {}  
  2. Event.prototype.on = function(eventName, callback) {  
  3. //注册事件监听  
  4. }  
  5. Event.prototype.trigger = function(eventName, data) {  
  6. //触发事件  
  7. }  
3、

要求实现一个多行文本输入框,固定宽度。可根据用户输入的内容多少进行高度自适应变化。如,用户输入了1行文字,则输入框显示为1行,而有2行文字,就显示2行。如微博的评论回复。

[javascript]  view plain copy
  1.   
  2.   
  3.   
  4.   
  5.     文本框换行  
  6.     "utf-8">  
  7.       
  8.   
  9.       
  10.   
  11.   
  12.   
  13.     "o" class="txt">来呀,来编辑我呀~  
  14.   
  15.   
  16.   

4、

编写一个JavasSript函数,给定一个DOM节点node和一个正整数n,返回node的所有第n代后代节点(直接子节点为第1代)

[javascript]  view plain copy
  1. function getDescendants(node, n) {  
  2. // return an Array  
  3. }  

[javascript]  view plain copy
  1. "text/javascript" >  
  2.     function getDescendants(node, n) {   
  3.         //node, n  
  4.         var childArr = [];  
  5.         var len,tempArr,childNodelist;                
  6.         childArr.push(node);  
  7.   
  8.         for(var i = 0; i
  9.             len = childArr.length;  
  10.             tempArr = [];  
  11.             for(var j = 0;j
  12.                 childNodeList = makeArray(childArr[j].childNodes);  
  13.                 tempArr = tempArr.concat(childNodeList);  
  14.             }  
  15.             childArr = tempArr;  
  16.         }  
  17.         return childArr;  
  18.     }  
  19.     var makeArray = function(obj){  
  20.         return Array.prototype.slice.call(obj,0);  
  21.     }  
  22.     var result = getDescendants(document.getElementById("content"),2);  
  23.     alert(result);  
  24.   

5、有2个int型已经去重的数组a和b,都是已经从小到大排序好的。要求遍历b数组的数字,如果这个数字出现在a中,就将其从a删去;反之将其插入到a的适当位置,使a保持排序状态。

[javascript]  view plain copy
  1. "text/javascript" charset="utf-8">  
  2. //有2个int型已经去重的数组a和b,都是已经从小到大排序好的。要求遍历b数组的数字,  
  3. //如果这个数字出现在a中,就将其从a删去;反之将其插入到a的适当位置,使a保持排序状态。  
  4. var mySort = {};  
  5.   
  6. mySort.sortArr = function(a, b) {  
  7.     var pos = 0;  
  8.     for (var i = 0; i < b.length; i++) {  
  9.         pos = mySort.checkRepeat(a, b[i],pos);  
  10.     }  
  11. }  
  12.   
  13. mySort.checkRepeat = function(a, v, pos) {  
  14.     var isChanged = false;                
  15.     if (a != null && a != undefined && a.length > 0) {      
  16.         for (var j = pos; j < a.length; j++) {  
  17.             if (a[j] == v) {  
  18.                 a.splice(j, 1);   
  19.                 break;  
  20.             } else if (a[j] > v) {  
  21.                 a.splice(j, 0, v);  
  22.                 break;  
  23.             }   
  24.         }     
  25.         if(j == a.length){  
  26.             a.push(v);  
  27.         }         
  28.         return j;  
  29.     }     
  30.   
  31. }  
  32.   
  33. var a = [2,7,12,25,36,64];  
  34. var b = [2,3,9,32,36,56,87];  
  35.   
  36. document.write("合并前数组a为:"+a.toString()+"
    "
    );  
  37. document.write("合并前数组b为:"+b.toString()+"
    "
    );  
  38.   
  39. mySort.sortArr(a,b);  
  40.   
  41. document.write("合并后数组a为:"+a.toString());  
//结果是:

合并前数组a为:2,7,12,25,36,64
合并前数组b为:2,3,9,32,36,56,87
合并后数组a为:3,7,9,12,25,32,56,64,87

6、请描述一下从用户输入网址开始,到网页最后呈现出来的全过程,越详细越好,包括各种事件等。

7、8、请评价以下代码并给出改进意见。

if (window.addEventListener) {  
    var addListener = function (el, type, listener, useCapture) {  
        el.addEventListener(type, listener, useCapture);  
    };  
} else if (document.all) {  
    addListener = function (el, type, listener) {  
        el.attachEvent("on" + type,  
            function () {  
                listener.apply(el);  
            });  
    };  
}  

 
  

问:1、为什么最终小狗叫了200声汪?请详细说明为什么。2、修改代码setTimeout部分代码,实现每隔1秒调用i(从1到10递增)次dog()。

1、第一题重点在于函数作用域的问题。

2、 修改后的setTimeout函数是

[javascript]  view plain copy
  1. for (var i = 0; i < 10; i++) {  
  2.     (function(a) {  
  3.         setTimeout(function() {  
  4.             for (var j = 1; j <= a; j++) {  
  5.                 document.write(dog()+" "+a+"
    "
    );  
  6.             }  
  7.         }, 1000);  
  8.     })(i+1);  
  9. }  

你可能感兴趣的:(前端)