[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