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


Posted in Javascript onAugust 27, 2019

本文实例讲述了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.3water.com/code/HtmlJsRun测试上述代码运行效果。

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

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

Javascript 相关文章推荐
JavaScript 权威指南(第四版) 读书笔记
Aug 11 Javascript
javascript 控制 html元素 显示/隐藏实现代码
Sep 01 Javascript
JavaScript中的几个关键概念的理解-原型链的构建
May 12 Javascript
手机端 HTML5使用photoswipe.js仿微信朋友圈图片放大效果
Aug 25 Javascript
Bootstrap表格制作代码
Mar 17 Javascript
Javascript刷新页面的实例
Sep 23 Javascript
简述Angular 5 快速入门
Nov 04 Javascript
Vue工程模板文件 webpack打包配置方法
Dec 26 Javascript
Vue.js实现表格渲染的方法
Sep 07 Javascript
浅谈从React渲染流程分析Diff算法
Sep 08 Javascript
深入理解Puppeteer的入门教程和实践
Mar 05 Javascript
ant design vue导航菜单与路由配置操作
Oct 28 Javascript
微信小程序模板消息限制实现无限制主动推送的示例代码
Aug 27 #Javascript
jQuery实现判断滚动条滚动到document底部的方法分析
Aug 27 #jQuery
JS多个表单数据提交下的serialize()应用实例分析
Aug 27 #Javascript
解决Vue中 父子传值 数据丢失问题
Aug 27 #Javascript
原生javascript自定义input[type=radio]效果示例
Aug 27 #Javascript
基于JS抓取某高校附近共享单车位置 使用web方式展示位置变化代码实例
Aug 27 #Javascript
使用Vue.js中的过滤器实现幂方求值的方法
Aug 27 #Javascript
You might like
php完全过滤HTML,JS,CSS等标签
2009/01/16 PHP
PHP实现的下载远程图片自定义函数分享
2015/01/28 PHP
Laravel执行migrate命令提示:No such file or directory的解决方法
2016/03/16 PHP
php+ajax实现仿百度查询下拉内容功能示例
2017/10/20 PHP
Laravel如何使用数据库事务及捕获事务失败后的异常详解
2017/10/23 PHP
Javascript优化技巧(文件瘦身篇)
2008/01/28 Javascript
javascript 弹出层组件(升级版)
2011/05/12 Javascript
js 完美图片新闻轮转效果,腾讯大粤网首页图片轮转改造而来
2011/11/21 Javascript
JQuery拖拽元素改变大小尺寸实现代码
2012/12/10 Javascript
关于js中alert弹出窗口文本换行问题简单详细说明
2012/12/11 Javascript
javascript-简单的日历实现及Date对象语法介绍(附图)
2013/05/30 Javascript
获取阴历(农历)和当前日期的js代码
2016/02/15 Javascript
浅析Node.js实现HTTP文件下载
2016/08/05 Javascript
js 中rewrap-ajax.js插件实例代码
2017/10/20 Javascript
Node.js中你不可不精的Stream(流)
2018/06/08 Javascript
vue模式history下在iis中配置流程
2019/04/17 Javascript
js实现抽奖的两种方法
2020/03/19 Javascript
vue之封装多个组件调用同一接口的案例
2020/08/11 Javascript
[52:08]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第一局
2016/03/05 DOTA
Python读取环境变量的方法和自定义类分享
2014/11/22 Python
Python基于回溯法子集树模板解决旅行商问题(TSP)实例
2017/09/05 Python
R语言 vs Python对比:数据分析哪家强?
2017/11/17 Python
详解Python 重学requests发起请求的基本方式
2020/02/07 Python
python+selenium+PhantomJS抓取网页动态加载内容
2020/02/25 Python
CSS3使用transition实现的鼠标悬停淡入淡出
2015/01/09 HTML / CSS
HTML5 placeholder(空白提示)属性介绍
2013/08/07 HTML / CSS
韩国现代百货官网:Hmall
2018/03/21 全球购物
美国羽绒床上用品第一品牌:Pacific Coast
2018/08/25 全球购物
英国最大的在线照明商店:Litecraft
2020/08/31 全球购物
小学国庆节活动方案
2014/02/11 职场文书
建筑工地质量标语
2014/06/12 职场文书
秦始皇兵马俑导游词
2015/02/02 职场文书
房贷工资证明范本
2015/06/12 职场文书
MySQL创建定时任务
2022/01/22 MySQL
将MySQL的表数据全量导入clichhouse库中
2022/03/21 MySQL
5个pandas调用函数的方法让数据处理更加灵活自如
2022/04/24 Python