【面试】前端面试题系列(一)

3016次阅读 203人点赞 作者: WuBin 发布时间: 2021-05-17 16:29:31
扫码到手机查看

JS面试题

查看如下代码,得出A(2)的运行结果【滴滴面试-考察闭包】

var a = 0,
    b = 0;
function A(a) {
  A = function (b) {
    alert(a + b++);
  };
  alert(a++);
}
A(1);
A(2);

题目解析: 口说无凭,先打印各个阶段的结果来查看下:

var a = 0,
    b = 0;
function A(a) {
    console.log('b', b); // 12行
  A = function (b) {
    console.log('a', a); // 14行
    console.log('b', b); // 15行
    console.log('c', a + b++); // 16行
  };
  console.log('a', a++); // 18行
}
console.log(A); // 20行
A(1);
console.log(A); // 22行
A(2);

根据结果,我们运行过程一目了然了。

  1. 当执行A(1)的时候,func-A就是外层的A, 先执行内层的A,由于A是全局变量,因此内层的A函数会替代外层的A函数,执行的结果就是console.log('a', a++); =》输出a,1,并且对a++,所以A(1)的结果就是先输出a,1,然后a执行++=1++后a的值就是2, 由于是闭包,因此结果存在闭包中,不会因A(1)执行完毕而销毁,然后A=func..()作为全局变量替换了外层的函数A。如22行看到的那样。
  2. 当执行A(2)的时候,函数A已经被内层函数A替换了,因此A(2)执行的实际是内层的函数,这时候传入的参数是2,执行a+b++ 《=》 2(A(1)执行完后a=2) + 2(A(2)传入的参数2)= 4,所以A(2)后的结果是4
执行后打印的结果:4

原型链的指向[滴滴面试]

// 问 : a的原型链指向谁?
const b = 2;
a = b;

a 的原型是指向是 Number不是指向 b,b 是基础类型,所以 a 是重新赋值,a 的原型指向是 Number。

遍历嵌套对象【滴滴】

编写函数获得对象中的值1,必须使用到str = 'a.b.c';

// 需要遍历的对象
var obj = {
  a: {
    b: {
      c: 1,
    },
  },
};
var str = "a.b.c";

题目解答:

const find = (obj, str) => {
  let arr = [];
  // 循环str字符串,遍历每个字母(本例默认每个key都是字母情况)
  for (const key in str) {
    // hasOwnProperty() 方法会返回一个布尔值,
    // 指示对象自身属性中是否具有指定的属性(也就是,是否有指定的键)。
    if (Object.hasOwnProperty.call(str, key)) {
      // str[key]即是str中的每个字母=>a . b . c
      if (str[key] != ".") {
        // 只要不是点就添加入数组
        arr.push(str[key]);
      }
    }
  }
  // 最终数组中的结果
  console.log(arr, ["a", "b", "c"]);
  try {
    return `${obj[ arr[0] ][ arr[1] ][ arr[2] ]}`;
    // 等价 obj['a']['b']['c']
  } catch (error) {
    return undefined;
  }
};

console.log(find(obj, 'a.b.c')) // 得到1

这道题的重点就是要知道检索对象中包含的值有什么方法。方法有两种:

  1. []后缀中包括住一个字符串表达式的方法 如:obj[a]
  2. 可以使用.表示法 如:obj.a
  3. 其中上面的解法就是采用[]获取对象中的值。

  4. Object.prototype.hasOwnProperty()-MDN解释

Webpack

webpack都用过哪些loader

  • babel-loader → 转义代码
  • css-loader → 加载 css,支持文件导入
  • style-loader → 把 css 代码注入到 javaScript 中,
  • scss-loader → 转义 scss
  • less-loader → 转义 less
点赞 支持一下 觉得不错?客官您就稍微鼓励一下吧!
关键词:前端面试、JS
推荐阅读
  • uniapp实现被浏览器唤起的功能

    当用户打开h5链接时候,点击打开app若用户在已经安装过app的情况下直接打开app,若未安装过跳到应用市场下载安装这个功能在实现上主要分为两种场景,从普通浏览器唤醒以及从微信唤醒。

    10049次阅读 659人点赞 发布时间: 2022-12-14 16:34:53 立即查看
  • Vue

    盘点Vue2和Vue3的10种组件通信方式

    Vue中组件通信方式有很多,其中Vue2和Vue3实现起来也会有很多差异;本文将通过选项式API组合式API以及setup三种不同实现方式全面介绍Vue2和Vue3的组件通信方式。

    4677次阅读 346人点赞 发布时间: 2022-08-19 09:40:16 立即查看
  • JS

    几个高级前端常用的API

    推荐4个前端开发中常用的高端API,分别是MutationObserver、IntersectionObserver、getComputedstyle、getBoundingClientRect、requ...

    14754次阅读 967人点赞 发布时间: 2021-11-11 09:39:54 立即查看
  • PHP

    【正则】一些常用的正则表达式总结

    在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。了解一些常用的正则表达式,能大大提高你的工作效率。

    13963次阅读 525人点赞 发布时间: 2021-10-09 15:58:58 立即查看
  • 【中文】免费可商用字体下载与考证

    65款免费、可商用、无任何限制中文字体打包下载,这些字体都是经过长期验证,经得住市场考验的,让您规避被无良厂商起诉的风险。

    12705次阅读 1023人点赞 发布时间: 2021-07-05 15:28:45 立即查看
  • Vue

    Vue3开发一个v-loading的自定义指令

    在vue3中实现一个自定义的指令,有助于我们简化开发,简化复用,通过一个指令的调用即可实现一些可高度复用的交互。

    16943次阅读 1357人点赞 发布时间: 2021-07-02 15:58:35 立即查看
  • JS

    关于手机上滚动穿透问题的解决

    当页面出现浮层的时候,滑动浮层的内容,正常情况下预期应该是浮层下边的内容不会滚动;然而事实并非如此。在PC上使用css即可解决,但是在手机端,情况就变的比较复杂,就需要禁止触摸事件才可以。

    15465次阅读 1257人点赞 发布时间: 2021-05-31 09:25:50 立即查看
  • Vue

    Vue+html2canvas截图空白的问题

    在使用vue做信网单页专题时,有海报生成的功能,这里推荐2个插件:一个是html2canvas,构造好DOM然后转canvas进行截图;另外使用vue-canvas-poster(这个截止到2021年3月...

    30556次阅读 2403人点赞 发布时间: 2021-03-02 09:04:51 立即查看
  • Vue

    vue-router4过度动画无效解决方案

    在初次使用vue3+vue-router4时候,先后遇到了过度动画transition进入和退出分别无效的情况,搜遍百度没没找到合适解决方法,包括vue-route4有一些API都进行了变化,以前的一些操...

    26529次阅读 2041人点赞 发布时间: 2021-02-23 13:37:20 立即查看
交流 收藏 目录