javaScript 基础知识汇总(八)
1、Map Set WeakMap 和WeakSet
Map
是一个键值对的集合,主要的方法包括:
new Map() 创建Map
map.set(key,value) 根据键(key)存储值(value).
map.get(key) 根据键返回值,如果map中该值不存在,返回undefined
map.has(key) 如果键值存在,返回true,否则返回false
map.delete(key) 移除该键的值
map.clear() 清空map
map.size 返回当前元素个数
let map = new Map();
map.set('', 'str1'); // 字符串作为 key
map.set(, 'num1'); // 数字作为 key
map.set(true, 'bool1'); // 布尔值作为 key
// 还记得普通对象 Object 吗?它将会把所有的键转化为字符串类型
// 但是 Map 将会保留键的类型,所以下面这两个是不同的:
alert( map.get() ); // 'num1'
alert( map.get('') ); // 'str1'
alert( map.size ); //
将Object转化为Map
通过一个方法Object,entries(obj),它可以返回一个对象的键值对数组,如下
let map = new Map(Object.entries({
name: "John",
age:
}));
遍历Map
let recipeMap = new Map([
['cucumber', ],
['tomatoes', ],
['onion', ]
]); // 迭代键(vegetables)
for (let vegetable of recipeMap.keys()) {
alert(vegetable); // cucumber, tomatoes, onion
} // 迭代值(amounts)
for (let amount of recipeMap.values()) {
alert(amount); // 500, 350, 50
} // 迭代键值对 [key, value]
for (let entry of recipeMap) { // 和 recipeMap.entries() 一样
alert(entry); // cucumber,500(等等)
}
recipeMap.forEach((value,key,map)=>{
alert(`${key}:${value}`);// cucumber: 500 等等});
Set
Set 是一个值得集合,这个集合中的所有的值仅出现一次
主要方法包括:
new Set() 创建Set,利用数组创建是可选的(任何迭代对象都可以)
set.add(value) 添加值,返回set本身
set.delete(value) 删除值,如果该value在调用方法的时候存在则返回true,否则返回false。
set.has(value) 如果set中存在该值则返回true,否则返回false。
set.clear() 清空set
set.size 元素的个数
Set 迭代
for ... of 或者 forEach
let set = new Set(["oranges", "apples", "bananas"]); for (let value of set) alert(value); // 和 forEach 相同:
set.forEach((value, valueAgain, set) => {
alert(value);
});
WeakMap 和 WeakSet
WeakMap 仅有如下方法:
weakMap.get(key)weakMap.set(key, value)weakMap.delete(key, value)weakMap.has(key)
WeakSet同理
这两者的键必须是对象
let weakMap = new WeakMap();
let obj = {};
weakMap.set(obj, "ok"); // 运行正常(对象作为键)
weakMap.set("test", "Whoops"); // 错误,因为“test”是原始类型
2、Json 方法
Json.stringify 将对象转换为json 完整语法:let json = JSON.stringify(value[, replacer, space])
Json.parse 将Json 转换为对象 语法:let value = JSON.parse(str[, reviver]);
let student = {
name: 'John',
age: ,
isAdmin: false,
courses: ['html', 'css', 'js'],
wife: null
};
let json = JSON.stringify(student);
alert(typeof json); // we've got a string!
alert(json);
/* JSON-encoded object:
{
"name": "John",
"age": 30,
"isAdmin": false,
"courses": ["html", "css", "js"],
"wife": null
}
*/
// a number in JSON is just a number
alert( JSON.stringify() ) // 1 // a string in JSON is still a string, but double-quoted
alert( JSON.stringify('test') ) // "test" alert( JSON.stringify(true) ); // true alert( JSON.stringify([, , ]) ); // [1,2,3]
// stringified array
let numbers = "[0, 1, 2, 3]"; numbers = JSON.parse(numbers); alert( numbers[] ); //
let user = '{ "name": "John", "age": 35, "isAdmin": false, "friends": [0,1,2,3] }';
user = JSON.parse(user);
alert( user.friends[] ); //
javaScript 基础知识汇总(八)的更多相关文章
- JavaScript基础知识汇总
1. 图片热区: <img src="logo.jpg" usemap="#logo"> <map id="logo" n ...
- javaScript 基础知识汇总(三)
1.循环:while 和 for while 循环 while(condition){ //代码 循环体 } do ... while 循环 let i =0; do { //循环体 }while( ...
- javascript基础知识 (八) BOM学习笔记
一.什么是BOM BOM(Browser Object Model)即浏览器对象模型. BOM提供了独立于内容 而与浏览器窗口进行交互的对象: 由于BOM主要用于管理窗口 ...
- javaScript 基础知识汇总(六)
1.基本类型与对象的区别 基本类型:是原始类型的中的一种值. 在JavaScript中有6中基本类型:string number boolean symbol null undefined 对 ...
- javaScript 基础知识汇总(五)
1.垃圾回收 JavaScript 的内存管理是自动的,不能强制执行或者阻止执行 可达性 JavaScript中主要的内存管理概念是可达性. 什么是可达性? 定义一个对象 let user = { n ...
- javaScript 基础知识汇总(二)
1.运算符 术语或者叫法:一元运算符.二元运算符.运算元(参数) let x=0; x=5+2; //5和2为运算元,“+” 为二元运算符: x=-x; //"-" 为一元运算符 ...
- javascript 基础知识汇总(一)
1.<script> 标签 1) 可以通过<script> 标签将javaScript 代码添加到页面中 (type 和language 属性不是必须的) 2)外部的脚本可以通 ...
- JavaScript 基础知识汇总目录
一.标签.代码结构.现代模式.变量.数据类型.类型转换 GO 二.运算符.值的比较.交互.条件运算符.逻辑运算符 GO 三.循环 while 和 for .switch语句.函数.函数表达式和箭头函数 ...
- javaScript 基础知识汇总 (十三)
1.Class 在JavaScript中 calss即类是一种函数 基本语法 class Myclass{ constructor(){} method1(){} method2(){} method ...
随机推荐
- iphone开发学习之路--基本语法
关键字:Objective-C(以下简称O-C)是C语言的一个超集,也就是C语言的语法O-C都是兼容的,所以为了避免冲突O-C的关键字都是以@符号开始的,比如:@class.@public .@try ...
- IOC读取配置文件
1. 创建一个bean文件 package com.longteng.utils; import org.springframework.beans.factory.annotation.Value; ...
- Java IO: PipedInputStream
原文链接 作者: Jakob Jenkov 译者: 李璟(jlee381344197@gmail.com) PipedInputStream可以从管道中读取字节流数据,代码如下: 01 InputSt ...
- iPhone X价格下跌!用户依旧冷眼相看为哪般?
X价格下跌!用户依旧冷眼相看为哪般?" title="iPhone X价格下跌!用户依旧冷眼相看为哪般?"> 其实对于刚刚过去的2017年手机市场来说,根本没有一款 ...
- 为啥Waymo和Uber间的官司,这么难界定?
自动驾驶作为被众多巨头和创业者看好的技术及领域,已有众多企业涉足其中.在自动驾驶尚未完全落地.制定统一标准前,每家企业都在争分夺秒地进行研发,试图率先抢占自动驾驶的高地.毕竟一旦成功,就能够创造巨大的 ...
- Lego:美团点评接口自动化测试实践
概述 接口自动化概述 众所周知,接口自动化测试有着如下特点: 低投入,高产出. 比较容易实现自动化. 和UI自动化测试相比更加稳定. 如何做好一个接口自动化测试项目呢? 我认为,一个“好的”自动化 ...
- shortcuts 快捷键
Home » Linux » shortcuts 快捷键 Page Updated 2018-12-12 19:23 shortcuts 快捷键 移动光标 Ctrl – a :移到行首 Ctrl – ...
- React中key的讲解
通过阅读React的文档我们知道React这个框架的核心思想是,将页面分割成一个个组件,一个组件还可能嵌套更小的组件,每个组件有自己的数据(属性/状态);当某个组件的数据发生变化时,更新该组件部分的视 ...
- WEB前端工程师简历
一个热爱前端的工程师 关于我 我的作品 ZENRON 关于我 求职意向 作品集 技术掌握 我的经历 联系我 关于我 英语/CET-4 坐标/苏州 状态/求职 我叫Zenron, 现居住苏州, 是一名前 ...
- CSS 双飞翼布局
10 Jul 2016 » CSS 双飞翼布局:总共分三栏,左侧栏Left,中间主栏Main,右侧栏Right 第一步,建立三个div,不过注意,中间Main需要加一个wrap div. 整个结构看起 ...