前端面试题(三)

2019-05-17  本文已影响0人  月半女那

1. 服务器端渲染(ssr:service side render)

优点:

2. react-redux实现原理

3. react 高阶组件

  1. 属性代理:通过被包裹的react组件来操作props
  2. 反向继承: 高阶组件继承于被包裹的react组件

4. router4 withRouter

withRouter其实就是为了获取location,history, maatch 这些参数,其本质上就是一个高阶组件,提供一个context

本文参考:https://segmentfault.com/a/1190000017140200

webpack 参考资料https://www.jianshu.com/p/c395ec989abd

4. 面向对象

面向对象的两大概念:类和实例
类:对象的类型模板
实例: 根据类创建的对象
虽然js没有类的概念,但是它使用构造函数(constructor)作为对象的模板


new 创建一个对象都进行了哪些操作

  1. 创建一个空对象,用this变量引用该对象并继承该函数的原型
  2. 属性和方法加入到this的引用对象中
  3. 新创建的对象由this所引用,最后隐式的返回this
function newObj(fun,argument){
  var obj = {};
  if(fun && typeof fun === 'function'){
    o.__proto__ == fun.prototype;
    fun.apply(o,argument);
    return o;
  }
}

如果构造函数内部由return语句,且return后面跟着一个对象,new 命令返回retrun 指定的对象,否则直接返回this

5. 原型链

image

proto和prototype区别

  1. proto是普通对象的隐式属性,在new的时候,会指向prototype所指的对象
  2. proto实际上是某个实体对象的属性,而prototype则是属于构造函数的属性
    简而言之

5. 元素居中

1.文本居中:text-align:center

  1. 图片居中:父级:text-align:center
  2. 块级元素居中:margin-left:auto;margin-right:auto
  3. 单行文本竖直居中,让height和line-height相等(如果不确定高度,可以用padding)

6. vue双向绑定

通过数据劫持结合发布者-订阅者模式来实现的,vue通过object.defineProperty()来实现数据劫持
https://www.cnblogs.com/libin-1/p/6893712.html

7. web攻击正怎么防御

  1. xss(跨站脚本攻击):例如在表单中提交含有可执行的javascript的内容文本,如果服务器端没有过滤或转义这些脚本,而这些脚本由通过内容的形式发布到了页面上,这个时候如果有其他用户访问这个网页,那么浏览器就会执行这些脚本,从而被攻击,从而获取用户的cookie等信息

防御
对于敏感的cookie信息,使用HttpOnly,使document对象找不到cookie
对于用户输入的信息进行转义

  1. CSRF(跨站点请求伪造):CSRF攻击者在用户已经登录目标网站之后,诱使用户访问一个攻击页面,利用目标网站对用户的信任,以用户身份在攻击页面对目标网站发起伪造用户操作的请求,达到攻击目的。
    防御

https://blog.csdn.net/qq_27855219/article/details/88796366

8. flex布局

flex(flexible box)其中心思想是给予容器控制内部元素高度和宽度的能力
https://www.cnblogs.com/nuannuan7362/p/5823381.html

9. 原型和原型链以及构造函数的关联

  1. js中所有函数都有一个prototype属性,这个属性引用一个对象(fun.prototype),即原型对象,简称为原型
  2. 所有原型都有constructor属性和proto属性
  3. constructor属性指向自己的继承父类(即它的构造函数的原型)
  4. js中一切皆对象,而对象都有一个proto属性,
  5. object.prototype的proto指向null(最顶级的原型对象),所有原型链的最顶层都是object.prototype
  6. 注意:A instanceof B 是检查A的原型链上是否存在B.prototype
    function是最顶层的构造方法,所有对象都由function方法构造,包括object方法,function 方法
    object对象和function方法是相互依赖的
    原型链只有在索引值的时候才会用到,如果我们尝试获取对象的某个属性值,但该对象中并没有此属性值,那么js就会在其原型链对象中找,如果还没有,那么会一直在原型链中找,直到object.prototype,如果该对象原型链中没有找到,则返回undefined

9.柯里化函数

柯里化:又称为部分求值,是把接受多个参数的函数变化成一个接受一个单一参数的函数,并且返回一个新的函数的技,新函数接受余下参数并返回运算结果
其实质就是利用闭包的概念

10. 箭头函数不能使用的情况

  1. 定义字面量方法
const calculator = {
    array: [1, 2, 3],
    sum: () => {
        console.log(this === window); // => true
        return this.array.reduce((result, item) => result + item);
    }
};

console.log(this === window); // => true

// Throws "TypeError: Cannot read property 'reduce' of undefined"
calculator.sum();

因为运行的时候this.array未定义,在执行calculator.sum()的时候this指向windo,原因是箭头函数把函数上下文绑定到了window上,解决方案:

const calculator = {
    array: [1, 2, 3],
    sum() {
        console.log(this === calculator); // => true
        return this.array.reduce((result, item) => result + item);
    }
};
calculator.sum(); // => 6

把箭头函数变成普通函数

  1. 定义原型方法
    箭头函数会陶制运行时的执行上下文错误
function Cat(name) {
    this.name = name;
}

Cat.prototype.sayCatName = () => {
    console.log(this === window); // => true
    return this.name;
};

const cat = new Cat('Mew');
cat.sayCatName(); // => undefined

只要变成普通函数之后,被调用时的执行上下文就会指向新创建的cat实例

  1. 定义事件回调函数
const button = document.getElementById('myButton');
button.addEventListener('click', () => {
    console.log(this === window); // => true
    this.innerHTML = 'Clicked button';
});

应该修改为

const button = document.getElementById('myButton');
button.addEventListener('click', function() {
    console.log(this === button); // => true
    this.innerHTML = 'Clicked button';
});

在用户触发点击按钮的时候,事件回调函数中的this实际指向button

  1. 定义构造函数
    因为箭头函数在创建时this对象就绑定了,并不会指向对象实例
const Message = (text) => {
    this.text = text;
};
const helloMessage = new Message('Hello World!');
// Throws "TypeError: Message is not a constructor"

11. apply,call,bind

call,apply改变某个函数运行的上下文
call,apply区别就是接受参数的方式不太一样
call(this,arg1,arg2,...) -- call传递的是参数
apply(this,[arg1,arg2,...]) -- apply传递的是数组

bind会创建一个新函数,称为这个绑定函数时,绑定函数会以创建它时传入bind()方法的第一个参数作为this,

上一篇 下一篇

猜你喜欢

热点阅读