13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

前端基础知识整理汇总二

接上昨天的《前端基础知识整理汇总(上)》,这些知识虽然是很基础的,但是对于系统的梳理还是非常有帮助的,也希望这些内容对你有所帮助。

成都创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都网站制作、网站建设、外贸网站建设、四川网络推广、微信小程序开发、四川网络营销、四川企业策划、四川品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联为所有大学生创业者提供四川建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com

Call, bind, apply实现

 
 
 
 
  1. // call 
  2. Function.prototype.myCall = function (context) { 
  3.   context = context ? Object(context) : window  
  4.   context.fn = this; 
  5.  
  6.   let args = [...arguments].slice(1); 
  7.   const result = context.fn(...args); 
  8.   delete context.fn; 
  9.   return result; 
  10.  
  11. // apply 
  12. Function.prototype.myApply = function (context) { 
  13.   context = context ? Object(context) : window; 
  14.   context.fn = this; 
  15.  
  16.   let args = [...arguments][1]; 
  17.   let result; 
  18.   if (args.length === 0) { 
  19.       result = context.fn(); 
  20.   } else { 
  21.       result = context.fn(args); 
  22.   } 
  23.   delete context.fn; 
  24.   return result; 
  25.  
  26. // bind 
  27. Function.prototype.myBind = function (context) { 
  28.   let self = this; 
  29.   let args = [...arguments].slice(1);  
  30.   return function() { 
  31.     let newArgs = [...arguments]; 
  32.     return self.apply(context, args.concat(newArgs)); 
  33.   } 

原型与原型链

每一个JavaScript对象(null除外)在创建的时候会关联另一个对象,这个被关联的对象就是原型。每一个JavaScript对象(除了 null)都具有的__proto__属性会指向该对象的原型。JavaScript中所有的对象都是由它的原型对象继承而来,而原型也是一个对象,它也有自己的原型对象,这样层层上溯,就形成了一个类似链表的结构,这就是原型链。每一个对象都会从原型"继承"属性。

实例对象和构造函数都可以指向原型, 原型可以指向构造函数,不能指向实例(因为可以有多个实例)。

原型对象有两个属性,constructor 和 __proto__。

 
 
 
 
  1. function Person() {} 
  2. var person = new Person(); 
  3.  
  4. // 实例原型 === 构造函数原型 
  5. person.__proto__ === Person.prototype // true 
  6. // 原型构造函数 === 构造函数 
  7. Person.prototype.constructor === Person // true 

react diff

  1. 如果是同一类型的组件,按照原策略继续比较 virtual DOM tree。
  2. 如果不是,则将该组件判断为 dirty component,从而替换整个组件下的所有子节点。
  3. 对于同一类型的组件,有可能其 Virtual DOM 没有任何变化,如果能够确切的知道这点那可以节省大量的 diff 运算时间,因此 React 允许用户通过 shouldComponentUpdate() 来判断该组件是否需要进行 diff。

遍历对象

对象遍历方法总结:

异步加载脚本

默认情况下,浏览器是同步加载 JavaScript 脚本,即渲染引擎遇到