[TOC]
#### Set结构数据
特征:Set结构数据里面的内容不允许重复
<script type="text/javascript">
var s = new Set();
//向Set结构数据中追加内容
s.add(1);
s.add(2);
s.add(3);
s.add(2);
s.add(2);
s.add(2);
s.add(2);
console.log(s);
//查看Set结构数据长度
console.log(s.size);
</script>
<script type="text/javascript">
//初始化Set结构数据的时候,允许传入一个数组
var s = new Set(['a','b','c','b','d','c','b']);
console.log(s);
</script>
#### Set结构数据的方法
<script type="text/javascript">
//初始化Set结构数据的时候,允许传入一个数组
var s = new Set(['a','b','c','b','d','c','b']);
//删除数据
s.delete('b');
console.log(s);
//获得Set结构数据中有没有某个值
var result = s.has('cc');
console.log(result);
//清除Set数据中所有的成员
s.clear();
console.log(s);
</script>
#### 去重复
<script type="text/javascript">
var arr = ['a','b','c','b','d','c','b'];
arr = [...new Set(arr)];
console.log(arr);
</script>
<script type="text/javascript">
var arr = ['a','b','c','b','d','c','b'];
var s = new Set(arr);
arr = Array.from(s);
console.log(arr);
</script>
#### set数据的遍历
<script type="text/javascript">
var arr = ['a','b','c','b','d','c','b'];
var s = new Set(arr);
//console.log(s.keys());
//获得所有键值的遍历器对象
for (x of s.keys()) {
console.log(x);
}
s.forEach(x=>{
console.log(x);
})
</script>
#### Map结构的数据是一种键值对(键名=>键值)形式,键名可以是任意类型的数据
<script type="text/javascript">
var m = new Map();
m.set(1,2);
console.log(m.get(1)); //2
var obj = {a:1,b:2};
m.set(obj,'后盾人');
console.log(m.get(obj)); //后盾人
console.log(m.has(obj)); //true
m.delete(obj);
console.log(m); //obj
</script>
#### Map初始化
Map结构的数据在创建的时候,允许传入一个二维数组.二维数组中的每个子数组都分别是一个键值对
<script type="text/javascript">
var m = new Map([
['name','后盾人'],
[2>1,123]
])
console.log(m);
console.log(m.get(2>1));
</script>
#### Map 遍历
<script type="text/javascript">
var m = new Map([
['name','后盾人'],
[2>1,123],
[1,666]
])
for (x of m.keys()) {
console.log(x);
}
//name , 2 ,1
for (x of m.values()) {
console.log(x);
}
//后盾人 , 123,666
for (x of m.entries()) {
console.log(x[0]+'=>'+x[1]);
}
m.forEach((v,k)=>{
console.log(v,k);
})
v-->键值 k->健名
</script>
- html&jquery网页特效
- 标签分类及特点
- 关于文字标签
- 网页定时跳转
- css透明度和插件
- 0.前端常用工具
- 1.tab切换效果
- 2.tab切换效果多个代码复用
- 3.百度新闻导航条效果
- 4.解决鼠标移入过快的问题
- 5.滚动条位置
- 6.元素尺寸
- 7.全选反选操作
- 8.固定定位
- 9.开关效果
- 10.节点操作
- 11.仿小米商品展示效果
- 12.仿小米商品展示效果复用
- 13.固定导航栏效果
- 14.凡客轮播图效果
- 15.顶部下滑广告效果
- 16.京东左右滑动轮播图
- 17.京东左右滑动无缝轮播图
- 18.选择器
- 19.筛选
- 20.开关效果
- 21.滑动效果
- 22.小米商品效果css实现
- 23.元素水平垂直居中
- laravel5.6
- LARAVEL 介绍&安装
- javascript & css 脚手架
- php常用工具类
- 安装laravel-ide-helper增强代码提示
- 使用migration创建表和数据填充
- 解决mysql5.7以下laravel不能执行数据迁移的问题
- 路由
- 登陆操作自定义模型
- 使用中间件middleware进行登录权限验证
- 进行表单验证处理
- 使用laracasts-flash定制消息提示
- 资源路由
- 宝塔面板安装fileinfo扩展
- laravel上传处理与使用hdjs快速实现前端上传组件
- thinkphp
- phpstorm
- phpstorm安装插件
- 定义快捷键
- 关闭提示
- 将代码实时同步到远程服务器
- sublime
- composer
- git使用
- git安装和配置作者信息
- git新建项目和维护项目
- git日志操作
- git别名操作
- git分支操作
- git生成发布压缩包
- git系统别名
- gitrebase操作
- 使用SSH与GITHUB远程服务器进行无密码连接
- 本地版本库主动使用remote与远程GITHUB进行关联
- 本地分支与GITHUB远程分支同步
- 项目实战-新入职员工参与项目开发时分支使用
- 自动部署
- ios开发
- linux
- 1.centos6.5 mysql忘记登入密码
- html5
- 标签
- 表单
- 音频与视频
- webstorage储存
- canvas
- css3
- 01.CSS3布局
- 02.transition动画
- 03.animation动画
- 04.flex弹性盒模型
- Less
- gulpjs
- es6
- ES6模块化
- let和const命令
- ES6函数扩展&解构赋值
- JavaScript之数据遍历
- class类
- Set和Map数据结构
- Vue
- 1.创建第一个应用
- 2.属性动态绑定
- 3.表达式
- 4.解决phpstorm不识别ECMASCRIPT6语法的问题
- 5.watch监听属性
- 6.使用object与array控制class
- 7.条件渲染
- 8.循环
- 9.变异方法
- 10.事件
- 11.表单
- 12.组件
- 13.css过渡动
- 14.js库控制vue过渡动作
- 15.自定义指令directive
- 16.使用vue-cli初始化单页面应用
- 17.Vue-router路由
- 18.vuex
- 19.vue-cli
- webpack
- zanui
- nodejs