这段时间看了《你不知道的JavaScript》上卷,对很多知识有了重新的认识,所以在这里罗列一些知识点作为巩固。 

作用域和闭包

词法作用域
  • 变量赋值操作会执行的两个动作

  答:编译器会在当前作用域中声明一个变量,前提是之前没有声明过。运行时引擎会在内存中查找该变量然后为它赋值。

  • RHS 和 LHS 查询

  答:查找容器用LHS查找,查找相应值用RHS查找

  • 在作用域顶层无法找到目标变量,在严格模式和非严格模式下有什么结果?

  答:非严格模式会创建一个全局变量,严格模式不会并且会报错。

  • with的副作用

  答:将变量泄露到全局上

 function foo( obj ) {
with( obj ) {
a = 2;
}
}
var obj = { b: 3 };
foo( obj );
console.log( obj.a ); // undefined
console.log( a ); // 2 -------> a泄露到了全局上
  • 匿名函数的三个缺点

  答:1、不利于调试

    2、降低可读性

    3、在递归时容易出错,由于递归是调用自身,匿名函数无法用函数名调用自身。

  • IIFE是什么

  答:自执行函数,有两种形式:

 (function(xx) {...})();
(function(xx) {...}());
  • JS的块作用域以及如何隐式模拟块作用域?

  答:js没有强类型语言那样的块作用域,可以用let声明变量达到块作用域实现的效果。

  • let 和 var 在变量声明有什么区别?

  答:let声明的变量不会提升,var会。

  • 提升(变量、函数有什么区别)

  答:函数比变量更早提升。

闭包
  • 闭包产生的原理
 function foo() {
function bar() {};
/*...*/
}
        当函数可以记住并且访问所在的词法作用域时,就产生了闭包,即使函数是在当前词法作用域之外执行。
         bar对foo内部作用域的引用就叫做闭包。
  • 闭包遇上for循环,问题、机制、解决办法(考虑let)

  答:详情参见我前面关于闭包的博客。

  • 模块的两个必要条件

  答:1、要有一个外部嵌套函数。

    2、封闭函数必须返回至少一个内部函数。

  • import 和 module 的区别

  答:import会导入模块中的一个或多个API分别绑定在一个变量上,module将整个模块的API导入并绑定到一个变量上。

this和对象原型

this
  • 胖箭头 => 的作用原理

  答:用当前词法作用域覆盖了this本来的值。

  • this是运行时绑定还是编译时绑定?

  答:运行时。

  • this的四个绑定及其原理

  答:1、默认绑定:默认绑定全局变量window。

    2、隐式绑定

    3、显式绑定:使用call()、apply()

    4、new绑定:函数创建对象时用new

  • 绑定的优先级

  答:new、显式 > 隐式 > 默认

  • 为什么setTimeout()中的this会默认绑定到window?

  答:setTimeout是一个定义在全局中的函数,所以该函数的this默认为window。

  • 写一个硬绑定bind(obj, target);
 function bind(fn, target) {
return function() {
return fn.apply(target, arguments);
};
}
  • 硬绑定的优势

  答:任由外部如何变动,内部的this绑定对象不会改变。

  • 使用new调用函数时会发生的四个步骤?

  答:1、创建一个全新的对象。

    2、对这个新对象执行[prototype]链接。
    3、这个新对象会被绑定到函数调用的this。

    4、如果函数没有返回值,那么new表达式中的函数调用会自动返回这个新对象,否则返回函数返回值。

对象
  • js中的六个基本类型、六个内置对象

  答:六个基本类型:null、string、number、boolean、undefined、object

    六个内置对象:String、Number、Boolean、Object、Function、Array

  • 函数从来不会属于某一个对象
  • 对象中内置的get函数的函数名和函数值分别代表什么?

  答:函数名------->对象属性名,函数值------->对象属性值

  • in 和 hasOwnPrototype 的区别

  答:in会在对象中以及原型链中查找对象是否含有该属性,而hasOwnPrototype只会在该对象中查找。

  • for...in 的特点?为什么说数组的遍历尽量不用 for...in?

  答:会遍历对象所有可枚举的属性,并且不一定按照顺序遍历。

  • 类的继承其实就是复制,js不能复制
  • 隐式混入和显式混入的区别

  答:前者直接全部“复制”过来,后者用call、apply

原型
  • 原型链上存在隐式屏蔽 
  • Foo.prototype的 .constructor 属性是一直存在的吗?

  答:不是,它是默认的。当你的prototype对象改变了,这个属性就不存在了除非你手动添加。

  • var b = Object.create(a);的作用机制

  答:创建一个对象b并关联到a。

行为委托
  • 一句话概括

  答:函数的继承,对象的委托

  • 委托的两个原则

  答:1、状态保存在委托者,而不是委托目标。

    2、避免在[prototype]链上的不同位置使用相同的命名

  • 委托的实质?

  答:某些对象找不到方法或者属性的引用时可以把请求委托给另一个对象。

  • 根据下面函数继承写出相应的行为委托
    函数继承:
 function A(name) {
this.name = name;
}
A.prototype.sayName = function() {
console.log(this.name);
};
function B(name) {
A.call(this, name);
}
B.prototype = Object.create(A.prototype);
var b = new B('Nic');
b.sayName(); //Nic
    行为委托:
 var A = {
init: function(name) { this.name = name; },
sayName: function() { console.log(this.name); }
};
var B = Object.create(A);
B.init('Nic');
B.sayName() //Nic
怎么改变的:
  • 将函数封装对象
    • 将构造函数内部的变量定义封装成一个函数
    • 将prototype对象的函数逐一封装进该对象
  • 将两个对象关联
    • 此时没有继承的说法了,关联不是上下级的关系,而是任意的
    • 关联后可以自定义或者封装新对象的一些属性及方法
  • 注意:尽量避免暴露委托
class
  • class不能声明属性只能声明方法
 class A {
constructor(name, age) {
this.name = name;
this.age = age;
}
sayName() {
console.log('hello, my name is: '+this.name);
}
}
var a = new A('wind', 20);
a.sayName(); //hello, my name is: wind

API设计原则

  • 最小特权原则:最小限度的暴露必要内容,而将其他内容都“隐藏”起来(将变量声明在某个作用域内尽量不在全局作用域中)
  • 尽量避免匿名函数
  • 关联关系中尽量避免函数名重复,会引发屏蔽覆盖的副作用
  • 内部委托(在内部调用)比直接委托(直接使用)可以让API接口更加清晰
  • 委托最好在内部实现,不要轻易的暴露出去

Javascript基础知识小测试(一)的更多相关文章

  1. java基础知识小总结【转】

    java基础知识小总结 在一个独立的原始程序里,只能有一个 public 类,却可以有许多 non-public 类.此外,若是在一个 Java 程序中没有一个类是 public,那么该 Java 程 ...

  2. Javascript基础知识总结一

    Javascript基础知识总结一 <!DOCTYPE html> <html> <head lang="en"> <meta chars ...

  3. 学习javascript基础知识系列第三节 - ()()用法

    总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...

  4. java基础知识小小结

    java基础知识小总结 在一个独立的原始程序里,只能有一个 public 类,却可以有许多 non-public 类.此外,若是在一个 Java 程序中没有一个类是 public,那么该 Java 程 ...

  5. JavaScript 基础知识 - BOM篇

    前言 本篇文章是JavaScript基础知识的BOM篇,如果前面的<JavaScript基础知识-DOM篇>看完了,现在就可以学习BOM了. 注意: 所有的案例都在这里链接: 提取密码密码 ...

  6. 学习javascript基础知识系列第二节 - this用法

    通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...

  7. (转)JAVA AJAX教程第二章-JAVASCRIPT基础知识

    开篇:JAVASCRIPT是AJAX技术中不可或缺的一部分,所以想学好AJAX以及现在流行的AJAX框架,学好JAVASCRIPT是最重要的.这章我给大家整理了一些JAVASCRIPT的基础知识.常用 ...

  8. JavaScript基础知识整理

    只整理基础知识中关键技术,旨在系统性的学习和备忘. 1.在 JScript 中 null 和 undefined 的主要区别是 null 的操作象数字 0,而 undefined 的操作象特殊值NaN ...

  9. JavaScript基础知识笔记

    做前端几年了,一直疏于整理归纳,所以这两天把基础看了一遍,加上使用经验,整理了基础知识中关键技术,旨在系统性的学习和备忘.如果发现错误,请留言提示,谢谢! 重要说明:本文只列举基础知识点,中级和高级内 ...

随机推荐

  1. java调用oracle存储过程,返回结果集

    package com.srie.db.pro; import java.sql.CallableStatement; import java.sql.Connection; import java. ...

  2. 从[NOI2008志愿者招募]浅谈线性规划在网络流构图上的巧用

    首先来看一下题..http://www.lydsy.com/JudgeOnline/problem.php?id=1061 1061: [Noi2008]志愿者招募 Description 申奥成功后 ...

  3. 我为什么不看好微信小程序

    我自认为对新技术还是比较有热情的,可对于小程序这个“新技术”,我却完全是被动的.去年9月份的时候,微信小程序开始内测,瞬间引爆朋友圈.知乎等一众分享平台.当时我大概了解了一下,觉得从技术角度上来说没啥 ...

  4. JDK源码分析-AtomicInteger

    AtomicInteger可以看做Integer类的原子操作工具类.在java.util.concurrent.atomic包下,在一些使用场合下可以取代加锁操作提高并发性.接下来就从几个方面来介绍: ...

  5. twemproxyRedis协议解析探索——剖析twemproxy代码正编

    这篇文章会对twemproxyRedis协议解析代码部分进行一番简单的分析,同时给出twemproxy目前支持的所有Redis命令.在这篇文章开始前,我想大家去简单地理解一下有限状态机,当然不理解也是 ...

  6. python之twisted模块安装

    Twisted是一个事件驱动的网络框架. 最近开始学习了解Twisted,首先肯定要安装twisted模块. 但是在cmd下执行:pip install twisted 出现了下面的问题:" ...

  7. <C++Primer>第四版 阅读笔记 第三部分 “类和数据抽象”

    类定义了数据成员和函数成员:数据成员用于存储与该类类型的对象相关联的状态:而函数成员则负责执行赋予数据意义的操作. 第12章 类 一个类可以包含若干公有的.私有的和受保护的部分:在public部分定义 ...

  8. JAVA_file(1)

    1.基本概念的理解 绝对路径:绝对路径就是你的主页上的文件或目录在硬盘上真正的路径,(URL和物理路径)例如:C:xyz est.txt 代表了test.txt文件的绝对路径.http://www.s ...

  9. java基础知识点---equal,==,hashcode

    1.==比较对象之间的地址是否相同 student a=new student(1); student b=new student(1); a==b   false b=a; a==b   true ...

  10. Docker网络代理设置

    背景 在一些实验室环境,服务器没有直接连接外网的权限,需要通过网络代理.我们通常会将网络代理直接配置在/etc/environment./etc/profile之类的配置文件中,这对于大部分操作都是可 ...