一、ES5及ES6

  (一)严格模式

  (二)bind/call/apply(改变上下文this指向,都是函数对象的方法)

    1、bind:返回值是一个函数

    2、call:返回值是一个对象

    3、apply:返回值是一个对象

  (三)JSON.parse/JSON.stringify

    1、JSON.parse():将json字符串转为json对象,严格模式下使用(IE7及以下不兼容)

    2、JSON.stringify():将json对象转为json字符串,严格模式下使用(IE7及以下不兼容)

  (四)let:取代var,声明变量

    1、script:全局作用域

      function:局部作用域

      let:块级作用域

        1)声明let声明变量,会产生块级作用域

        2)let声明的变量不在做变量提升,只能先声明,后使用

        3)同一个作用域,let不可以重复声明同一个变量

        4)for循环有两个块级作用域,for本身是一个作用域,for循环体又是for中的一个子级作用域

        5)let声明的变量不再是window的属性

      2、const:用于声明常量

  (五)变量的解构赋值:ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)

    1、以前,为变量赋值,只能直接指定值。比如:

      let a = 1

      let b = 2

      let c = 3

    现在,ES6允许这样:

      let [a, b, c] = [1, 2, 3]

    或是这样:

      let {a, b, c} = {a: 1, b: 2, c: 3}

    上面三种方法的结果都是一样的;本质上,后两种通过解构赋值的写法属于“模式匹配”,只要判定了等号两边的模式相同(解构),左边的变量就会被赋予对应的值(赋值)

  (六)字符串的扩展方法

    1、includes("字符串",下标位置);查找指定的字符串是否在父串中包含,返回布尔值

    2、startsWith("字符串",下标位置);查找指定的字符串是否在父串的开头部分,返回布尔值

    3、endsWith("字符串",下标位置);查找指定的字符串是否在父串的结尾部分,返回布尔值

    注:includes和startsWith中第二个参数是从指定位置向后查找;endsWith中第二个参数是从指定位置(不包含)向前查找

    4、repeat();重复指定的字符串

      注:1)如果是小数,会自动向下取整

        2)字符串,可转先将字符串转为数字,不可转NaN为0;

        3)小于等于-1,报错;小于0大于-1取0

    5、``:模板字符串

      例:` ${变量名} `

  (七)箭头函数()=>{}

    1、唯一的好处:箭头函数中的this指向的是箭头函数所有作用域绑定的对象(this所在作用域的父级作用域绑定的对象)

  (八)Symbol():是ES6新增的第七种基本数据类型,特点是保证每一个变量中的值具有唯一性

    1、唯一的好处:可以解决原生对象中key被覆盖的问题

  (九)Set和Map结构

    1、Set集合,本质上就是对数组的一种包装;具有自动去除重复元素的特性

      1)如何创建set对象

        let set = new Set();

        let set = new Set([]);//里面为一维数组

      2)set属性:size:返回set对象的长度

      3)set的方法:

        a、add();添加元素

        b、delete();删除指定key的元素值

        c、has();判断指定元素是否在set对象中,返回布尔值

        d、clear();清空set对象

      4)遍历set对象:

        a、for of:for(变量 of 集合){}

        b、keys():获取set对象中所有的key

        c、values():获取set对象中所有的value

        d、entries():获取set对象中所有的key和value

        e、forEach(function(value,key,set){})

    2.map:解决原生JS对象中key是字符串的问题

      1)如何创建Map对象

        var map = new Map();

        var map = newMap([[]]);//里面为二维数组

      2)Map的属性

        size:返回map对象的长度

      3)map的方法

        a、set():添加元素

        b、get():获取元素

        c、delete():删除只能指定key的元素值

        d、has():判定指定元素是否在map对象中,返回布尔值

        e、clear():清空map对象

      4)遍历map对象

        a、for of:for(变量 of 集合){}

        b、keys():获取map对象中所有的key

        c、values():获取map对象中所有的value

        d、entries():获取map对象中所有的key和value

        e、forEach(function(value,key,set){})

  (十)数组去重

    1. var arr = [1,2,1,12,1,2,1,1,1,2,2,1,1];

      var set = [...new Set(arr)];

      console.log(set);

    //... : 扩展运算符

      var str = 'abcde';

      console.log([...str]);

  (十一)生成器函数

  (十二)class

    

  (十三)for in/for of

    区别:for in中的循环变量表示下标或key

       for of中的循环变量表示value或key

JS学习笔记Day15的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. Vue.js学习笔记(2)vue-router

    vue中vue-router的使用:

  3. JS 学习笔记--9---变量-作用域-内存相关

    JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...

  4. WebGL three.js学习笔记 使用粒子系统模拟时空隧道(虫洞)

    WebGL three.js学习笔记 使用粒子系统模拟时空隧道 本例的运行结果如图: 时空隧道demo演示 Demo地址:https://nsytsqdtn.github.io/demo/sprite ...

  5. WebGL three.js学习笔记 法向量网格材质MeshNormalMaterial的介绍和创建360度全景天空盒的方法

    WebGL学习----Three.js学习笔记(5) 点击查看demo演示 Demo地址:https://nsytsqdtn.github.io/demo/360/360 简单网格材质 MeshNor ...

  6. WebGL three.js学习笔记 创建three.js代码的基本框架

    WebGL学习----Three.js学习笔记(1) webgl介绍 WebGL是一种3D绘图协议,它把JavaScript和OpenGL ES 2.0结合在一起,通过增加OpenGL ES 2.0的 ...

  7. vue.js 学习笔记3——TypeScript

    目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...

  8. 2019-4-29 js学习笔记

    js学习笔记一:js数据类型   1:基本数据类型       number类型(整数,小数)      String类型          boolean类型        NaN类型其实是一个nu ...

  9. 一点感悟:《Node.js学习笔记》star数突破1000+

    写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...

随机推荐

  1. Python3漏洞扫描工具 ( Python3 插件式框架 )

    目录 Python3 漏洞检测工具 -- lance screenshot requirements 关键代码 usage documents README Guide Change Log TODO ...

  2. Web开发人员学习路线图

    http://www.runoob.com/w3cnote/2018-web-developer.html

  3. MFC桌面电子时钟的设计与实现

    目录 核心技术 需求分析 程序设计 程序展示 (一)核心技术 MFC(Micosoft Foundation Class Libay,微基础类库)是微基于Windows平台下的C++类库集合,MFC包 ...

  4. Windows Server 2012 R2 配置FTP服务器

    Windows Server 2012 R2 安装IIS参考上一篇配置IIS 8.0:https://www.cnblogs.com/aq-ry/p/9329310.html 搭建完IIS 后,最近又 ...

  5. day 6 - 1 知识点小节

    python2 与 python3 的区别 1. print.input.生成器 #python2 print() print 'abc' range() xrange() 生成器 raw_input ...

  6. 英语进阶系列-A04-英语升级练习二

    古诗背诵 要求:背诵和朗读,然后翻译成现代文,并绘制图像描述图中的内容,同时看看某些内容可以用什么单词替换,时间限制到15 minutes. 速记词汇系列 要求:将词汇快速朗读并记忆,时间为8 min ...

  7. MongoDB的搭建并配置主从以及读写分离

    1.环境准备  1.Centos7 2.mongodb3.4.93.三台机器IP分别是:10.170.1.16.10.170.1.18.10.170.1.33 2.mongdb数据库的安装 如下操作是 ...

  8. idea右键无法新建Java Class

    项目中新建目录之后,要在该目录下新增java Class文件,右键——>New发现无对应选项. 原因:新建目录之后需要设置目录作用,从而让idea识别. 方法:File-Project Stru ...

  9. 使用 ESP8266 制作 WiFi 干扰器 - 无需密码即可使用任何 WiFi

    嘿,朋友,我是 Kedar,你有没有想阻止所有的 WiFi信号?或者只是想从 WiFi 踢某人或邻居 WiFi .那么,本玩法是你等待结束的时刻了.这是为你提供的.仅需 $8 的 DIY Wifi 干 ...

  10. Spring Cloud:多环境配置、eureka 安全认证、容器宿主机IP注册

    记录一下搭建 Spring Cloud 过程中踩过的一些坑,测试的东西断断续续已经弄了好多了,一直没有时间整理搭建过程,时间啊~时间~ Spring 版本 Spring Boot:2.0.6.RELE ...