当前位置: 首页 > 编程笔记 >

JS常见面试试题总结【去重、遍历、闭包、继承等】

翟嘉志
2023-03-14
本文向大家介绍JS常见面试试题总结【去重、遍历、闭包、继承等】,包括了JS常见面试试题总结【去重、遍历、闭包、继承等】的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了JS常见面试试题。分享给大家供大家参考,具体如下:

JavaScript面试题总结

1,首先是数组去重算法:给一个数组,去掉重复值

(function() {
    var arr = [1, 2, 3, 3, 4, ];
    function unique() {
      var result = [];
      var tem = {};
      for (var i = 0; i < arr.length; i++) {
        if (!tem[arr[i]]) {
          result.push(arr[i]);
          tem[arr[i]] = 1;
        }
      }
      return result;
    }
})();

2,多维数组,至少3层的遍历,将数组整合一维数组,网上给出的方案

//遍历多维数组
var arr = [1, 2, 3, [4, [5, [6]]]]; // arr.length
Array.prototype.each = function(fn) {
  try {
    //1 目的: 遍历数组的每一项 //计数器 记录当前遍历的元素位置
    this.i || (this.i = 0); //var i = 0 ;
    //2 严谨的判断什么时候去走each核心方法
    // 当数组的长度大于0的时候 && 传递的参数必须为函数
    if (this.length > 0 && fn.constructor == Function) {
      // 循环遍历数组的每一项
      while (this.i < this.length) { //while循环的范围
        //获取数组的每一项
        var e = this[this.i];
        //如果当前元素获取到了 并且当前元素是一个数组
        if (e && e.constructor == Array) {
          // 直接做递归操作
          e.each(fn);
        } else {
          //如果不是数组 (那就是一个单个元素)
          // 这的目的就是为了把数组的当前元素传递给fn函数 并让函数执行
          //fn.apply(e,[e]);
          fn.call(e, e);
        }
        this.i++;
      }
      this.i = null; // 释放内存 垃圾回收机制回收变量
    }
  } catch (ex) {
    // do something
  }
  return this;
}

3,获得url查询参数方案

1)一个是用正则表达式方法

//获取url参数
function GetQueryString(name) {
  var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
  //js match返回的是一数组
  var r = location.search.substr(1).match(reg);
  if (r != null) {
    return r[2];
  } else {
    return null;
  }
}

2)另外一种就是利用split结合数组遍历实现,这个比较容易实现就不贴代码了

4,正则表达式去掉空格

/**去掉字符串前后所有空格*/
function trim(str){
return str.replace(/(^\s*)|(\s*$)/g, "");
}

5,闭包的概念考察

6,原型继承如何实现,原型继承有两种方案

1)第一种是利用prototype

var obj={name:'seven'};
var a=function(){};
a.prototype=obj;
var aa=new a();
alert(aa.name);

 2)第二种是利用apply或者call

function people(name,age){
  //属性
  this.name=name;
  this.age=age;
  //方法
  this.show=function(){
    console.log("my name is"+this.name+" and I am "+this.age+" years old");
  };
}
function student(name,age,school){
  people.apply(this,arguments);
  this.school=school;
  this.showYourself=function(){
    console.log("my name is"+this.name+" and I am "+this.age+" years old"+" my school is"+ this.school);
  };
}
var tom=new student('tom','19','xtu');
tom.showYourself();

7,ES6常用知识点考察

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》

希望本文所述对大家JavaScript程序设计有所帮助。

 类似资料:
  • <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <meta name="viewport" content="width=device-width, initial-scale=1.0">

  • 这两天在准备招行fintech产品面试,找了网上挺多面经的,现在来汇总一下看到的各种面经中的问题(侵删) 招行: 基本信息:自我介绍;学校;个人优缺点(结合例子);学术研究;用一个词形容自己;性格中最大的缺点? 过往经历:实习经历介绍、遇到的困难、收获;最有成就感的事;你人生中收到过最有意义的挑战是什么?怎样解决的?;你刚才提到自己喜欢发现问题、解决问题,你过往的经历里有没有这样的例子?;举一个项

  • 诶嘿,粉丝破百了耶,但哥们没别的才艺,就整个面经合集吧521爱你们 (特意选的下午五点21分发布😋,我看谁还敢说单身狗不懂浪漫) 先写个时间线吧😋(这里只写有面试机会的,简历和测评挂的不尽其数就不写了) 时间线 腾讯-产品运营-暑期实习 3.16 初试 3.21 复试(寄) 网易-电商运营(日常) 3.21 电话面(寄) 字节-内容运营(日常) 3.27电话面(说完到岗时间就寄了,同样的错误我

  • Spring容器有哪些功能? 什么是ApplicationContext,它背后的原理和应用场景你清楚吗? 什么是IOC? 一个组件向自己内部注入组件有哪些方法? 什么是对象安全? Spring框架中,一个组件是怎样向自己内部注入组件的 使用spring容器怎样获取一个组件,如何动态获取Bean对象? 在spring框架下面,Bean的属性lazy-init有什么作用,默认值是多少 怎样把所有的组

  • 本文向大家介绍Redis中一些最常见的面试问题总结,包括了Redis中一些最常见的面试问题总结的使用技巧和注意事项,需要的朋友参考一下 前言 经过长达一周的奔波和面试,电话面试,回首今天终于成功的入职了,总共面试了大概10家公司,包括阿里,京东,IBM等等,京东技术过了,学历因为非统招就被pass了,阿里面了2次电话面试就没下文了,估计是我当时最后提问题的时候减分了吧,其他的也有一些offer,不

  • 分为三部分进行总结,分别是专业类、兴趣爱好类、个人情况类 专业类 1.你的实习经历,这期间你做了什么,学到了什么,领悟到了什么 2.说出你最喜欢的几个服装品牌,喜欢它们的什么?如果有子品牌,希望在哪个品牌工作? 3.你对我们品牌的认识感受。 4.怎么看待市场流行趋势和品牌调性之间的关系,如何去把握这之间的平衡 5.服装设计的各类要素重要程度的排列(廓形一面料-色彩-秩序(节奏)-图案) 6.针对服