set和map结构,class类
1、set数据结构和map数据结构:
//1 创建set
var s=new Set([,,])
console.log(s)
//2 set的属性,size(和length是一样的)
console.log(s.size) //3
//3 set的方法,(1)add方法-添加可以链式操作,返回的事set本身 console.log(s.add('a').add('b').add('c'))
//delete(value)-删除,返回布尔值,true或者false
console.log(s.delete('a'))
console.log(s)
//has(value) 判断是否有某个值,返回布尔值
console.log(s.has('a'))
//clear()方法 清除数据,没有返回值
// s.clear();
// console.log(s)
//遍历方法有 s.keys()返回遍历键值,s.values()返回遍历value s.entries()返回键值和value对,s.forEach()方法,遍历每个成员
console.log(s.keys())
console.log(s.values())
console.log(s.entries())
s.forEach(function(value,key,set){
console.log(value+'wir')
})
(2)map:map不同于set(集合),它使用的是[键,值]的形式储存数据,与object不同的是object键值只能是字符串也就是字符串-值,而map允许键值可以是对象也就是值-值
//一 创建map
let map=new Map([['a',],['{b:2}',]])
console.log(map)
//二 方法 set(key,value),设置键名key对应的值为value,然后返回整个map结构,也就是可以链式操作,如果key有值,则会被后来的覆盖
//get(key) 返回key对应的值,没有则undefined
//delete(key)删除key对应的值,返回布尔值 true或者false
//has(key)判断是否有某个key,返回布尔值true false
//clear() 清空
//遍历方法 keys():遍历key值
console.log(map.keys())
//values() :遍历values
console.log(map.values())
//entries():键值对遍历
console.log(map.entries())
//forEach()
map.forEach(function (key,value,map) {
console.log(key+'和'+value)
})
//NaN是互补相等的,但是在map里面认为是同一个,不能重复添加,对象{}可以
map.set({},'a').set({},'b')
console.log(map)
2、class类:JS语言的传统方法是通过构造函数,定义并生成新对象,是一种基于原型的面向对象系统。现在js越来越像java等面向对象语言差别很大,所以在ES6中新增了类的概念,可以使用 class 关键字声明一个类,之后以这个类来实例化对象
// const Xub= function (a, b){
//   this.a = a;
//   this.b = b;
//   return this;
// };
//
// Xub.prototype = {
//   constructor:Xub,
//   print: function (){
//     console.log(this.a + ' ' + this.b);
//   }
// };
//
//
// const xub= new Xub('hello', 'world').print();
class Xub{
    constructor(a,b){
        this.a=a;
        this.b=b;
        // return this
    }
    print(){
        console.log(this.a,this.b)
    }
}
const result=new Xub('hello','world').print()
// 1 Xub这个类除了构造方法,还定义了一个print方法。
// 注意,定义“类”的方法的时候,前面不需要加上function这个关键字,直接把函数定义放进去了就可以了。
// 另外,方法之间不需要逗号分隔,加了会报错。
// 2 构造函数的prototype属性,在ES6的“类”上面继续存在。而且类的所有方法都定义在类的prototype属性上面。
console.log(Xub.prototype)
//  3 constructor方法是类的默认方法,通过new命令生成对象实例时,自动调用该方法。
// 一个类必须有constructor方法,如果没有显式定义,一个空的constructor方法会被默认添加。
set和map结构,class类的更多相关文章
- JAVA中的数据结构——集合类(线性表:Vector、Stack、LinkedList、set接口;键值对:Hashtable、Map接口<HashMap类、TreeMap类>)
		
Java的集合可以分为两种,第一种是以数组为代表的线性表,基类是Collection:第二种是以Hashtable为代表的键值对. ... 线性表,基类是Collection: 数组类: person ...
 - Java开发知识之Java中的Map结构
		
Java开发知识之Java中的Map结构 一丶Map接口 Map没有实现Collection接口,提供的是Key 到Value的映射. Map中.不能包含相同的Key,每个Key只能映射一个Value ...
 - Java中的集合(十四) Map的实现类LinkedHashMap
		
Java中的集合(十四) Map的实现类LinkedHashMap 一.LinkedHashMap的简介 LinkedHashMap是Map接口的实现类,继承了HashMap,它通过重写父类相关的方法 ...
 - .net(C#)中结构和类的区别
		
static void Main(string[] args) { //类型 //结构:值类型 //类:引用类型 //声明的语法:class struct //在类中,构造函数里,既可以给字段赋值,也 ...
 - CSS3 结构伪类选择器 详解
		
1 CSS3 结构伪类选择器 1.E:root 匹配E元素所在的根元素 即:html 2. E:nth-child(n) (1)匹配E元素的父元素中第n个子元素,(2)且该位置的子元素类型必须是E类型 ...
 - Atitit java的异常exception 结构Throwable类
		
Atitit java的异常exception 结构Throwable类 1.1. Throwable类 2.StackTrace栈轨迹1 1.2. 3.cause因由1 1.3. 4.Suppres ...
 - ES6笔记(6)-- Set、Map结构和Iterator迭代器
		
系列文章 -- ES6笔记系列 搞ES6的人也是够无聊,把JS弄得越来越像Java.C++,连Iterator迭代器.Set集合.Map结构都出来了,不知道说什么好... 一.简单使用 1. iter ...
 - Map/Reduce的类体系架构
		
Map/Reduce的类体系架构 Map/Reduce案例解析: 先以简单的WordCount例程, 来讲解如何去描述Map/Reduce任务. public static void main(Str ...
 - C#中结构与类的区别
		
一.类与结构的示例比较: 结构示例: public struct Person { string Name; int height; int weight public bool overWeight ...
 
随机推荐
- 10 jQuery的事件绑定和解绑
			
1.绑定事件 语法: bind(type,data,fn) 描述:为每一个匹配元素的特定事件(像click)绑定一个事件处理器函数. 参数解释: type (String) : 事件类型 data ( ...
 - HBase  ——  单机环境搭建
			
一.安装前置条件说明 1.1 JDK版本说明 HBase 需要依赖JDK环境,同时HBase 2.0+ 以上版本不再支持JDK 1.7 ,需要安装JDK 1.8+ .JDK 安装方式见本仓库: Lin ...
 - 前端页面统计beacon调研
			
目录 为什么使用beacon beacon特性 beacon 示例 参考资料 主要用于测试html的新特性beacon,使用beacon向后端发送请求,代替xhr或jsonp, 好处是支持页面unlo ...
 - Python笔记【3】_元组学习
			
#!/usr/bin/env/python #-*-coding:utf-8-*- #Author:LingChongShi #查看源码Ctrl+左键 ''' tuple:以圆括号“()”括起来,以“ ...
 - 003.SQLServer数据库镜像高可用部署
			
一 数据库镜像部署准备 1.1 数据库镜像支持 有关对 SQL Server 2012 中的数据库镜像的支持的信息,请参考:https://docs.microsoft.com/zh-cn/previ ...
 - C++ 洛谷 P1731 [NOI1999]生日蛋糕
			
P1731 [NOI1999]生日蛋糕 一本通上也有. 这TM是一道极其简单的深搜剪枝(DP当然可以的了,这里我只讲深搜). 首先圆柱公式:(有点数学基础都知道) V=πR2H S侧=π2RH S底= ...
 - 2018.8.19 2018暑假集训之maxnum
			
昨天去做志愿服务去了没写成Q_Q 今天再来一道 先放题面描述 设有n个正整数(n<=20),将它们联成一排,组成一个最大的多位数 设有n个正整数(n<=20),将它们联成一排,组成一个最大 ...
 - 【Aizu - 0118】Property Distribution
			
-->Property Distribution 原文是日语,算了算了,直接上我大中华母语吧 Descriptions: 在H * W的矩形果园里有苹果.梨.蜜柑三种果树, 相邻(上下左右)的 ...
 - 控制台程序秒变Windows服务(Topshelf)
			
项目中有些时候需要写服务,一般我们都是先创建控制台程序,测试,运行,成功之后再创建windows服务程序,这样好麻烦啊,有没有简单的控制台程序直接变成Widnows服务,经过查找,找到了Topshel ...
 - [深度学习]TensorFlow安装
			
virtualenv 可以用来建立一个专属于项目的python环境,保持一个干净的环境.只需要通过命令创建一个虚拟环境,不用的时候通过命令退出,删除.实践证明用虚拟环境能避免很多糟心的事. 下面介绍一 ...