1、垃圾回收

  JavaScript 的内存管理是自动的,不能强制执行或者阻止执行

  可达性

  JavaScript中主要的内存管理概念是可达性。

  什么是可达性?

  定义一个对象

  let user = {

    name:"XiaoMing"

  };

  user 应用了这个对象。 通过 user.name 可以取到“XiaoMing"这个值,则认为XiaoMing这个值是可达的。

  当 user= null;  ”XiaoMing“ 这个值就不可达了,此时JavaScript的垃圾回收机制就会自动从内存中将其清除。

2、Symbol 类型

  对象的属性键,根据规范只能使用 String 类型 和 Symbol 类型

  Symbol  表示唯一的标识符。

  创建方式; let id = new Symbol("id");        Symbol("id")中的id 为对id 的描述,

  并且即使描述相同,只要定义的变量不同,这个Symbol 这个对象就不一样

  字面量中的Symbol

  通过变量的方式将Symbol 对象作为属性的键

   示例:

  let id = Symbol("id");

  let user = {

    name:"XiaoMing",

    [id]:123

  };

  Symbol 在 for...in 中被跳过

  for(let key in user)

    alert(key);

  //Symbol       这个属性不会被展示出来,可以作为隐藏属性

  可以通过"."的方式使用 user.[id]。

  全局symbol

  在应用程序中想要访问同一个symbol 的时候可以使用 全局symbol 注册表

  使用方法:   Symbol.for(key);

  let id = Symbol("id); //从全局注册表中获取,如果不存在则创建。

  let idAgain = Symbol.for("id");  //再次读取

  此时id 和 idAgain是相同的

  Symbol.keyFor

  Symbol.keyFor 在内部全局注册表中来查找symbol 的键,只适用于全局,如果是非全局的则返回undefined

  let sym = Symbol.for("name");

  alert(Symbol.keyFor(Symbol.for(”name")));//name

  alert(Symbol.keyFor(Symbol.for(”id")));//undefined

  系统Symbol 不做展示。

3、对象方法和 this

  在对象方法中使用this

  let user ={

    name:"XiaoMing",

    sayHi:function(){

      alert(this.name);

    }

  };

  javaScript 中的this 和其它语言中的this 有些不同,JavaScript中的“this” 只有在执行的时候才确定它指向的是哪一个对象。

  简单总结:

  存储在对象中的函数称之为方法

  对象执行方法进行操作,obj.doSomething();

  方法可以将对象应用为this;

  this的值是在运行的时候求值的

  函数声明使用this 只有等到调用时才会有值

  函数可以在对象之间进行公用

  箭头函数没有this。在箭头函数中访问this,是外部传进来的。

4、构造函数 和操作符“new"

  构造函数

  构造函数在技术上是常规函数。不过有两个约定。

    1)它们的首字母必须大写

    2)只能用”new“ 操作符来执行

  例子:

  function User(name){

    this.name= name;

    this.isAdmin=false;

  }

  let user  = new User('jack');

  alert(user.name);//jack

  双语法构造函数: new.target

  function User(name){

    if(!new.target){

      return new User(name);

    }

    this.name= name;

  }

  let Xiao = User("Xiao");//内部已经封装好了,如果不用new关键字,则在构造函数内部自动使用new

  构造函数 Return

  通常情况下构造函数是没有Return 的

  如果有,规则如下:

    1)如果return 对象,则返回它,而不是this  

    2)如果return 一个原函数,则忽略。

  

  换一种说法,带有对象的 return 返回该对象,在所有其他情况下返回 this

  例如,这里 return 通过返回一个对象覆盖 this

 function BigUser() {

   this.name = "John";

   return { name: "Godzilla" };  // <-- returns 一个 object
} alert( new BigUser().name ); // 哇哦,得到了对象,name 属性值为 Godzilla ^^

这里有一个 return 空的例子(或者我们可以在它之后放置一个原函数):

 function SmallUser() {

   this.name = "John";

   return; // 完成执行,returns this

   // ...

 }

 alert( new SmallUser().name );  // John

  构造函数中的方法

  

 function User(name) {
this.name = name; this.sayHi = function() {
alert( "My name is: " + this.name );
};
} let john = new User("John"); john.sayHi(); // My name is: John /*
john = {
name: "John",
sayHi: function() { ... }
}
*/

javaScript 基础知识汇总(五)的更多相关文章

  1. javaScript 基础知识汇总 (十五)

    1.模块简介 什么是模块: 模块就是一个文件,一个脚本,通过关键字export 和 import 交换模块之间的功能. export 关键字表示在当前模块之外可以访问的变量和功能. import 关键 ...

  2. JavaScript基础知识汇总

    1. 图片热区: <img src="logo.jpg" usemap="#logo"> <map id="logo" n ...

  3. javaScript 基础知识汇总(三)

    1.循环:while 和 for while 循环 while(condition){ //代码 循环体 } do ... while  循环 let i =0; do { //循环体 }while( ...

  4. javaScript 基础知识汇总(六)

    1.基本类型与对象的区别 基本类型:是原始类型的中的一种值. 在JavaScript中有6中基本类型:string number  boolean  symbol  null  undefined 对 ...

  5. javaScript 基础知识汇总(二)

    1.运算符 术语或者叫法:一元运算符.二元运算符.运算元(参数) let x=0; x=5+2; //5和2为运算元,“+” 为二元运算符: x=-x; //"-" 为一元运算符 ...

  6. javascript 基础知识汇总(一)

    1.<script> 标签 1) 可以通过<script> 标签将javaScript 代码添加到页面中 (type 和language 属性不是必须的) 2)外部的脚本可以通 ...

  7. JavaScript 基础知识汇总目录

    一.标签.代码结构.现代模式.变量.数据类型.类型转换 GO 二.运算符.值的比较.交互.条件运算符.逻辑运算符 GO 三.循环 while 和 for .switch语句.函数.函数表达式和箭头函数 ...

  8. javaScript 基础知识汇总 (十三)

    1.Class 在JavaScript中 calss即类是一种函数 基本语法 class Myclass{ constructor(){} method1(){} method2(){} method ...

  9. javaScript 基础知识汇总(七)

    1.数组 特点:数组是可以存储有序集合的对象. 声明: let arr = new Array();   let arr=[]; 大多数情况下我们使用第二种. let fruits = [" ...

随机推荐

  1. 关于sprintf的使用注意

    今天在使用sprintf时,本想简单一点,将第一个参数直接定义为一个字符型的指针(cher  *str;),结果没想到程序变得死死的,老老实实的将第一个参数重新变回字符型数组吧(char str[10 ...

  2. 初探java流操作

    在处理集合时,我们通常会迭代遍历它的元素,并从每个元素上执行某项操作.例如,假设我们想要对某本书中的所有长单词进行计数.首先我们要将所有单词放入一个列表中: String contents = new ...

  3. IDEA创建普通java和web项目教程

    1.第一个javaSE项目 01.双击idea运行IDE 02.配置JDK 03.创建项目的workspace .iml文件里面是当前项目的一些配置信息! 相当于web项目中的web.xml文件 04 ...

  4. VS、C#配置R语言开发环境

    R语言学习笔记(一)——在Vs.C#中配置R语言开发环境. 最近在学习小众的R语言,所以将遇到的问题记录下来供大家参考,不足之处欢迎大家交流指正. 至于R语言的介绍就不多说了,它集成了复杂的数学算法, ...

  5. 一个项目中:只能存在一个 WebMvcConfigurationSupport (静态文件失效之坑)

    一个项目中:只能存在一个 WebMvcConfigurationSupport 在一个项目中WebMvcConfigurationSupport只能存在一个,多个的时候,只有一个会生效. 静态文件访问 ...

  6. powermockito单元测试之深入实践

    概述 由于最近工作需要, 在项目中要做单元测试, 以达到指定的测试用例覆盖率指标.项目中我们引入的powermockito来编写测试用例, JaCoCo来监控单元测试覆盖率.关于框架的选择, 网上讨论 ...

  7. Docker系列开篇之Virtual Machine VS Container(一)

    前言 本节开始我们正式进入Docker系列,网上关于Docker相关文章如数家珍,写博客至今,我也一直在朝着如何写出通俗易懂且不枯燥的文章这个目标前进,喃喃自语的同时也希望看到文章的童鞋能明白我在讲什 ...

  8. npm包开发与发布

    把通用的功能开发成npm包,便用使用和维护,更重要的是可以分享给广大的开发者,是不是很激动人心! 那么,步骤如下: 1.创建项目 创建项目目录,npm init ,根据需要输入配置信息(建完后也可以在 ...

  9. Hyper-v设置linux固定ip

    一.创建CentOS 7专用的虚拟交换机 打开Hyper-v控制面板,找到右边的“虚拟交换机管理器” 进去后,点击“新建虚拟网络交换机”,填写名称后,选择“内部” 打开网络中心,修改配置如下图,注意i ...

  10. Java中的时间二三事

    实习过程中对于时间的处理有很多,有的还涉及到从数据库取出时间,所以做一些总结,想到那先写到哪,慢慢补充.    首先最常见的是java.util中的Date类,这个类封装了当前的日期和时间,它实际是计 ...