es6的基本数据详解
| 1 2 3 |
var s = new Set(); [2,3,5,4,5,2,2].map(x =>s.add(x)); for(i of s){console.log(i)} |
| 1 2 |
var set = new Set([1,2,3,4,4]); console.log([...set]); |
| 1 2 3 4 |
let set =new Set(); set.add({}); set.add({}); console.log(set.size); //输出值为2 |
- Set.prototype.constructor:构造函数,默认就是Set函数
- Set.prototype.size:返回Set实例的成员总数
- add(value):添加某个值,返回Set结构本身。
- delete(value):删除某个值,返回一个布尔值,表示删除是否成功。
- has( value):返回一个布尔值,表示参数是否为Set成员。
- clear( ):清除所有成员,没有返回值。
| 1 2 3 4 5 6 7 8 |
var s= new Set(); s.add(1).add(2).add(2); console.log("s.size:"+s.size); console.log(s.has(1));//true console.log(s.has(2));//true console.log(s.has(3));//false s.delete(2);//删除2的成员 console.log(s.has(2));//false |
| 1 2 3 |
var items = new Set([1,2,3,4,5]); var array = Array.from(items); console.log(array); |
| 1 2 3 4 |
function dedupe(array){ return Array.from(new Set(array)); } console.log(dedupe([1,2,3,3])); |
- keys( ):返回一个键名的遍历器
- values( ):返回一个键值的遍历器
- entries( ):返回一个键值对的遍历器
- forEach( ):使用回调函数遍历每个成员。
| 1 2 3 4 5 6 7 8 9 10 11 12 |
let set = new Set(['red','green','blue']); for ( let item of set.keys()){ console.log(item); } for(let item of set.values()){ for( let item of set.entries()){ |
| 1 2 |
Set.prototype[Symbol.iterator]===Set.prototype.values; //true |
| 1 2 3 4 5 |
let set=new Set(['red','green','blue']); for(let x of set) { console.log(x); } |
| 1 2 3 |
let set = new Set(['red','green','blue']); let arr = [...set]; console.log(arr); |
| 1 2 3 |
let arr=[3,5,2,2,5,5]; let unique=[...new Set(arr)]; console.log(unique); |
| 1 2 3 4 5 |
var ws = new WeakSet(); ws.add(1); //TypeError:Invalid value used in weak set ws.add(Symbol()); //TypeError:Invalid value used in weak set |
| 1 2 3 |
var a = [[1,2],[3,4]]; var ws = new WeakSet(a); console.log(ws); |
- WeakSet.prototype.add(value):向WeakSet实例添加一个新成员。
- WeakSet.prototype.delete(value):清除WeakSet实例的指定成员。
- WeakSet.prototype.has(value);返回一个布尔值,表示某个值是否在WeakSet实例中。
| 1 2 3 4 5 6 7 8 9 |
var ws = new WeakSet(); var obj = {}; var foo = {}; ws.add(window); ws.add(obj); console.log(ws.has(window));//true console.log(ws.has(foo));//false ws.delete(window); console.log(ws.has(window))//false |
es6的基本数据详解的更多相关文章
- JavaScript ES6 新特性详解
JavaScript ES6 带来了新的语法和新的强大功能,使您的代码更现代,更易读 const , let and var 的区别: const , let 是 ES6 中用于声明变量的新关键字. ...
- es6入门4--promise详解
可以说每个前端开发者都无法避免解决异步问题,尤其是当处理了某个异步调用A后,又要紧接着处理其它逻辑,而最直观的做法就是通过回调函数(当然事件派发也可以)处理,比如: 请求A(function (请求响 ...
- Es6 Promise 用法详解
Promise是什么?? 打印出来看看 console.dir(Promise) 这么一看就明白了,Promise是一个构造函数,自己身上有all.reject.resolve这几个眼熟的方 ...
- es6 Proxy对象详解
Proxy用于修改某些操作的默认行为,也可以理解为在目标对象之前架设一层拦截,外部所有的访问都必须先通过这层拦截,因此提供了一种机制,可以对外部的访问进行过滤和修改.这个词的原理为代理,在这里可以表示 ...
- es6 Reflect对象详解
Reflect是ES6为操作对象而提供的新API,而这个API设计的目的只要有: 将Object对象的一些属于语言内部的方法放到Reflect对象上,从Reflect上能拿到语言内部的方法.如:Obj ...
- es6实现继承详解
ES6中通过class关键字,定义类 class Parent { constructor(name,age){ this.name = name; this.age = age; } speakSo ...
- ES6 中 Promise 详解
Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果.从语法上说,Promise 是一个对象,从它可以获取异步操作的消息.Promise 提供统一的 API ...
- ES6中Promise详解
Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果.从语法上说,Promise 是一个对象,从它可以获取异步操作的消息. Promise 提供统一的 AP ...
- ES6 Promise用法详解
What is Promise? Promise是一个构造函数,接受一个参数(Function),并且该参数接受两个参数resolve和reject(分别表示异步操作执行成功后的回调函数.执行失败后的 ...
随机推荐
- 出现: object() takes no parameters 之后应该如何修改
这个错误花费了很多的时间去解决,包括重写代码也无济于事. 因为粗心,浪费了很多的时间在这个上面,特写此博客来记录,也希望朋友们不要粗心,特别是初学者. 接下来进入正文: 当在写self.XXX 下方 ...
- npx命令介绍
什么是npx 第一次看到npx命令是在 babel 的文档里 Note: If you do not have a package.json, create one before installing ...
- SQL server 数据库中插入中文变???格式乱码的问题另一种容易忽略的情况(C#操作dapper)
1.先查查 VS2015 中的XXX.cs页面中编码格式,记事本打开另存一下,编码格式可能是ANSI改为unioncode. (中文前面加N或者改排序规则解决不了的情况有可能是以上原因.)
- python封装configparser模块获取conf.ini值
configparser模块是python自带的从文件中获取固定格式参数的模块,因为是python只带的,大家用的应该很多,我觉得这个参数模块比较灵活,添加参数.修改参数.读取参数等都有对应的参数供用 ...
- python设置虚拟环境
一.介绍 虚拟环境-virtualenv是一个用于隔绝的python环境的工具,虚拟环境与本地环境互相隔离,互不影响,例如我们要安装django2.0的版本但是本地已经安装了1.1的,这时只需要在本地 ...
- vue-router路由动态传参query和params的区别
1.query方式传参和接收参数 //路由 { path: '/detail', //这里不需要参入参数 name: "detail", component: detail//这个 ...
- Javascrip动态添加样式,Dom操作,获取自定义属性
var layer=document.querySelector('.layer') 添加样式: 添加单个样式: layer.style.display="block" 添加多个样 ...
- 【spark】dataframe常见操作
spark dataframe派生于RDD类,但是提供了非常强大的数据操作功能.当然主要对类SQL的支持. 在实际工作中会遇到这样的情况,主要是会进行两个数据集的筛选.合并,重新入库. 首先加载数据集 ...
- 高可用Redis(三):Hash类型
1.哈希类型键值结构 哈希类型也是key-value结构,key是字符串类型,其value分为两个部分:field和value 其中field部分代表属性,value代表属性对应的值 上面的图里,us ...
- layUI弹出框提示
简单介绍:项目使用layUI框架好久了,也没来的及写一篇关于layUI弹出层的随笔.现在补上.经常用到的,一般都是在ajax成功回调函数后边写. //js代码 s和fail 是ajax返回的数据lay ...