Javascript1.8.5开始可以使用Object.freeze来冻结对象实现一个类似”枚举”类型。...Object.freeze(DaysEnum) 这就是js中的”枚举”!是不是很简单? 不过现在是2019年了,我们还可以使用const来定义对象。
Python集合又是一种新的数据类型,集合有两种形式:可变集合set()和不可变集合frozenset()两种,这两种集合操作方法比较类似,但是在底层性质上有截然想法的区别。...集合是一种无序的,不重复且不可随机访问的元素集合,在概念和运算上和数学中的集合类似,集合分为可变和不可变两种。...不可变集合构造(与可变集合类似,把set改为frozenset即可)。...1.集合不能想其他数据集一样使用特有的符号来构造,集合使用的语法符号是{},和字典是一样的,这时候直接使用{}来构造的,系统无法判断数据类型是字典还是集合,会默认为集合。...set9 = set() set99 = frozenset() 2.集合中不能包含字典和列表这样的可变类型元素 set10 = {'name', 19, [1, 2, 3, 2]} 列表不可哈希:TypeError
数据容器 , 就无法使用这两个数据容器 ; 本篇博客介绍一种新的 自带去重功能 数据容器 : " 集合 " , 集合 数据容器 中的元素 不能重复 ; 二、集合定义 集合 使用 大括号 {} 进行定义...; 定义 集合 数据容器 字面量 ; 如果其中有重复元素 , 会自动删除前面的重复元素 , 保留最后一个元素 ; {元素1, 元素2, 元素3} 定义 集合 数据容器 变量 ; 如果其中有重复元素 ,...会自动删除前面的重复元素 , 保留最后一个元素 ; 集合变量 = {元素1, 元素2, 元素3} 定义 空集合 数据容器 ; 集合变量 = set() 注意 : 如果集合中有重复的元素 , 会保留后面的元素...大括号 {} 定义 ; 三、代码示例 - 集合定义 在下面的集合中 , 分别定义了 集合字面量 / 集合变量 / 空集合 ; 其中定义集合变量时 , 定义了两个重复元素 ‘Tom’ 字符串 , {"Tom...", "Jerry", "Jack", "Tom"} 由于 集合 数据容器中的元素 不能重复 , 在集合中 , 这两个 Tom 字符串需要删除一个 , 这里将第一个 Tom 字符串被删除 , 保留第二个
一、LinkedList集合 LinkedList类是集合新增元素和删除元素效率比较好,该集合的里面维护一个双向循环的链表,链表中它的每一个元素可以引用方式记下前一个元素和后一个元素,把所有的元素连接起来就可以了...System.out.println("元素添加到集合后所有的元素:"+l.toString()); System.out.println("获取集合中的第一个元素:"...+l.getFirst()); System.out.println("获取集合中的最后一个元素:"+l.getLast()); } } 运行的结果: ?...System.out.println("元素添加到集合后所有的元素:"+l.toString()); System.out.println("删除集合中的第一个元素:"...六、总结 本文主要介绍了LinkedList集合、LinkedList中定义的方法。
定义:匿名函数顾名思义指的是没有名字的函数,在实际开发中使用的频率非常高!也是学好JS的重点。 匿名函数:没有实际名字的函数。...首先我们声明一个普通函数: //声明一个普通函数,函数的名字叫fn function fn(){ console.log(“张培跃”); } 然后将函数的名字去掉即是匿名函数: //匿名函数...JavaScript中是没有块级作用域的,例如: if(1==1){//条件成立,执行if代码块语句。...在这里简单介绍一下:闭包是可以访问在函数作用域内定义的变量的函数。若要创建一个闭包,往往都需要用到匿名函数。 2、模拟块级作用域,减少全局变量。...执行完匿名函数,存储在内存中相对应的变量会被销毁,从而节省内存。再者,在大型多人开发的项目中,使用块级作用域,会大大降低命名冲突的问题,从而避免产生灾难性的后果。
定义类 function Person() { // 属性 this.name = "张三" this.age = 20 // 方法 // 实例方法,需要new才能被调用
收集一些开发过程中精简短小实用的工具函数,每个函数如果有出处,会尽量标明可以做追溯。 千位分隔符的实现 function separate (num) { const reg = /(?...stackoverflow.com/questions/15900485/correct-way-to-convert-size-in-bytes-to-kb-mb-gb-in-javascript Js
文章目录 一、集合中的 “ << “ 操作符重载 1、使用集合中的 “ << “ 操作符添加一个元素 2、使用集合中的 “ << “ 操作符添加一个集合 二、完整代码示例 一、集合中的 “ << “...* @return 返回原集合, 该集合中已经添加了元素对象....“ << “ 操作符添加一个元素 向 集合 [“1”, “2”, “3”] 中 , 添加 元素 “4” , 最终结果是 [“1”, “2”, “3”, “4”] ; 代码示例 : //...“ << “ 操作符添加一个集合 向 集合 [“1”, “2”, “3”, “4”] 中 , 添加 集合 [“5”, “6”] , 最终结果是 [“1”, “2”, “3”, “4”, [“5”, “...6”]] ; 注意 : 如果 使用 " << " 操作符插入一个集合 , 则会 将该集合作为一个元素 , 插入到现有的集合中 ; 如 : 向 [“1”, “2”, “3”, “4”] 集合中插入 [“5
一般情况咱们排序大都按数字或字母顺序,但也有一些情况下,咱们可能需要自定义排序顺序。...array(可选): 调用 reduce() 的数组 initialValue(可选):作为第一次调用 callback 函数时的第一个参数的值。 如果没有提供初始值,则将使用数组中的第一个元素。...;如果没有提供 initialValue,那么accumulator取数组中的第一个值,currentValue取数组中的第二个值。...,不过还有一个问题,如果列表中有一个status不同的项(不在咱们的排序顺序中),就会出现问题。...因此,为了处理这个问题,咱们需要设置一个默认的sort字段来捕获排序中不需要的所有项。
JSON是JavaScript原生格式,这意味着在JavaScript中处理JSON数据不需要任何特殊的API或工具包。 JSON的规则很简单:对象是一个无序的“‘名称:值 '对”集合。...一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值' 对”之间使用“,”(逗号)分隔。 规则如下: 1)映射用冒号(“:”)表示。...名称1:值1,名称2:值2 3) 映射的集合(对象)用大括号(“{}”)表示。{名称1:值1,名称2:值2} 4) 并列数据的集合(数组)用方括号(“[]”)表示。...: 1)传统方式存储数据,调用数据 代码如下: <script type= "text/javascript" > //JS传统方式下定义"类" function Person...(id,name,age){ this .id = id; this .name = name; this .age = age; } //JS传统方式下创建"对象"
初识数组:新建一个数组 II....]; 这句话是定义数组的一种方法,之后,我们可以给这个数组赋值: var arr = [] arr[0] = 0; arr[1] = 1; console.log(arr[0]); console.log...(arr[1]) 赋值的方法也很简单,直接给数组对应的索引值的位置赋值即可与其他编程语言不同的是: JavaScript中的数组,长度是动态可变的,如果学过其他编程语言的朋友可能对这一点不是很习惯。...但事实上反而使得问题变得简单了,因此不需要再定义数组的时候就指定它的大小。 除了上面的这种创建数组的方法外,还有以下几种方法: // 1. 最简单的创建方法 var arr = []; // 2....+ " " + arr[1] + " " + arr[2] + " " + arr[3] + " " + arr[4]); ---- slice()方法 slice() 方法返回包含从数组对象中的
前言 JS中分两种数据类型,一种是基本数据类型,另外就是复杂数据类型,在描述一个事物对象,当比较复杂时,一般可以用数组和对象来存储 在Js中的对象,指的是一系列互相嵌套的键值对,在做web开发时,大多数控件都是以对象或数组的形式来提供给开发人员使用...那如何创建一个对象呢,如何给对象添加属性和方法?...在Js当中有一些方法,如下所示 01 方法1-使用文本字面量形式 这种方法创建对象是比较直接,常见的一种方式,就是使用大括号的方式,可以看做是js对象的本本标识,也就是说,可以通过输出字符串的形式来了解对象有哪些键值对...,它也是JSON形式,用于js的数据存储和传递,给对象添加属性和添加方法 如下代码所示 // 用大括号创建对象的方法,这种方法最常见,使用最频繁 var obj1 = {}; // 使用大括号创建一个内容为空的对象...添加了一个outPut方法,并提供实现了一个alert弹框 alert('给obj1添加了一个outPut方法'); } // 调用对象obj1下面的outPut方法 obj1.outPut()
在 Python 中 , 集合 set 是无序的 , 因此 集合 数据容器 不支持 使用 下标索引 访问 集合元素 ; 一、集合中添加元素 调用 集合#add(新元素) 函数 , 可以将新元素添加到 集合...数据容器中 ; 集合添加元素代码示例 : 原集合中有两个 Tom 字符串 , 只保留后面的 Tom 字符串 ; 添加元素时 , 添加 Trump 元素 , 原集合中没有该元素 , 添加成功 ; 有添加...Tom"} # 上述集合中有两个 Tom 字符串, 由于 集合 不能重复, 第一个 Tom 字符串被删除 print(f"names = {names}, type = {type(names)}")...调用 集合#remove(已有元素) 函数 , 可以将原来的元素从 集合 数据容器 中移除 ; 移除 集合 数据容器中的 元素时 , 先确定 集合 中存在该元素 , 如果移除不存在的元素 , 会报如下异常...调用 集合#pop() 函数 , 可以 从 集合 数据容器 中 随机取出一个元素 ; 集合中不支持使用 下标索引 访问元素 , 因此只能随机取出一个元素 ; 代码示例 : 使用 name 变量接收取出的元素
知识点表格截图:
确定性 给定一个集合,任给一个元素,该元素或者属于或者不属于该集合,二者必居其一,不允许有模棱两可的情况出现。 互异性 一个集合中,任何两个元素都认为是不相同的,即每个元素只能出现一次。...无序性 一个集合中,每个元素的地位都是相同的,元素之间是无序的。集合上可以定义序关系,定义了序关系后,元素之间就可以按照序关系排序。但就集合本身的特性而言,元素之间没有必然的序。
1、基本定义 delimiter 自定义符号 -- 如果函数体只有一条语句, begin和end可以省略, 同时delimiter也可以省略 create function 函数名(形参列表) returns...返回类型 -- 注意是retruns begin 函数体 -- 函数内定义的变量如:set @x = 1; 变量x为全局变量,在函数外面也可以使用 返回值 end...自定义符号 delimiter ; 示例: -- 自定义函数 delimiter $$ create function myfun3(ia int, ib int) returns int begin...return ia + ib; end $$ delimiter ; 2、需求 2.1 统计文章分类的数量,分类是树形结构,所以有一个先查询分类树形的级别的集合。
定义函数 在JavaScript中,定义函数的方式如下: function abs(x) { if (x >= 0) { return x; } else {...return -x; } } 上述abs()函数的定义如下: function指出这是一个函数定义; abs是函数的名称; (x)括号内列出函数的参数,多个参数以,分隔; { ... }之间的代码是函数体...由于JavaScript的函数也是一个对象,上述定义的abs()函数实际上是一个函数对象,而函数名abs可以视为指向该函数的变量。...-x; } }; 在这种方式下,function (x) { ... }是一个匿名函数,它没有函数名。...上述两种定义完全等价,注意第二种方式按照完整语法需要在函数体末尾加一个;,表示赋值语句结束。 摘自:廖雪峰的官方网站
js中const,var,let定义变量的区别 1.const定义变量不可以修改,而且必须初始化 const b = 2;//正确 // const b;//错误,必须初始化 console.log...('函数外const定义b:' + b);//有输出值 // b = 5; // console.log('函数外修改const定义b:' + b);//无法输出 2.var定义的变量可以修改...,如果不初始化会输出undefined,不会报错 var a = 1; // var a;//不会报错 console.log('函数外var定义a:' + a);//可以输出a...(); console.log('函数调用后var定义a为函数内部修改值:' + a);//可以输出a=4 3.let是块级作用域,函数内部使用let定义后,对函数外部无影响。...('函数内let定义c:' + c);//输出c=6 } change(); console.log('函数调用后let定义c不受函数内部定义影响:' + c);//输出c=3
private String address; private List teacherList; } 3.重点:然后配置xml //<-- 关联集合就是用
领取专属 10元无门槛券
手把手带您无忧上云