某公司的线上笔试题

 

1)编写正则表达式,匹配密码,要求密码必须以字母开头,必须有数字,字母,或   _  -  .  的组合 ,长度5-15位  

var reg = /^[a-zA-Z](?![a-zA-Z]+$)(?![0-9]+$)(?![-_.]+$)[a-zA-A\d-._]{4,16}$/g;

 

  ^   从头开始

  [a-zA-Z]        匹配的第一位是字母

  (?![a-zA-Z]+$)    向后预查到结尾 不匹配全是字母的情况

  (?![0-9]+$)       向后预查不匹配全是数字的情况

  (?![-_.]+$)      向后预查不匹配全是 - _  .的情况  

  [a-zA-Z\d.-_]{4,16}  因为前面第一位 的   []  消耗字符串, 所以剩余要匹配的长度减一  

  $          结尾      

这里主要运用到了   正则表达式的预查  

        更多关于  正则表达式 --->我的博客

  

2)用源生js 编写一个链式调用  new Box(100,100,red).addTo(body).addTo(body).delay(3000).remove();  实现 用过如上代码 向body 添加两个 100*100的红色的盒子,延时3S后移出

  小生不才  只是实现了效果,但是,应该有一部分不是这道题想要的

    function Box (wid,hei,col) {
      this.wid = wid || 0;
      this.hei = hei || 0;
      this.col = col || 'black';
      this.queue = [];    //队列储存生成的dom
    }
    Box.prototype.addTo = function(foo){    //这里也要注意,根据题,能在body插入多个Dom,所以,要生成的时候也要生成多个dom,
      this.foo = foo;                //所以   createElement要在这一步,  如果在上一步的话  new Box()只调用一次
      var box = document.createElement('div');  //这一步 插入多少次  只有一个dom(我线上笔试的时候就写错了)
      box.style.width = this.wid + 'px';
      box.style.height = this.hei + 'px';
      box.style.backgroundColor = this.col;
      document[foo].appendChild(box);
      this.queue.push(box);
      return this;
    }
    Box.prototype.delay = function(tim){ 
      return this;                  
    }                     
                          Box.prototype.remove
= function(){ var self = this; setTimeout(() => { self.queue.forEach(ele => { document[this.foo].removeChild(ele); }); }, this.tim); return this; }

 

 

//这个delay不会,去网上找的   , 
使用 循环占用cpu,但是他会在daaTo的dom显示出来之前就进入循环状态
,阻塞了前面dom生成的效果this.tim = tim;            
//循环占用cpu  还不能使用setTimeout ,
改变循环的判断值 ,
就像是 while(flag){} 开始flag是true,
计时器结束了 flag = false 
//然而这样是不行的,  改变了的 flag传不进去,  
如果把 计时器放在循环里头  那就是疯了。。。。
//网上的 做法是   
用 在循环里用  new Date().getTime() 和  
在循环外面 第一次执行就获取的 new Date().getTime()+timer 进行比较
//来当做定时器  (timer是指   定时器传进来的  毫秒数)

 

3)已知对象 obj = {'asfsd':'3123,'dsf':'2131,'gads':'3213','sdaf':2526}  实现将对象的key 按照ascii的顺序排序(这道题应该考的是数组克隆)

    var obj = {'abc':123,'cde':345,'bac':213,'def':456}
    function clone(src,tar){       //最简单的一个克隆  不对原对象进行改变
      for(var prop in src) {
          tar[prop] = src[prop];    
      }
    }
    var tar = {};
    clone(obj,tar);    
    var arrKey = [];
    for(var i in tar){          //便利出key的数组
      arrKey.push(i)
    }
    var arrOrder = arrKey.sort()    
    console.log(arrOrder);
posted @ 2018-04-09 15:33  清汤不加辣  阅读(717)  评论(0编辑  收藏  举报