最全总结 JavaScript Array 方法详解
前言
我们在日常开发中,与接口打交道最多了,前端通过访问后端接口,然后将接口数据二次处理渲染到页面当中。
二次处理的过程是 考验 Coder
对 Array
是否熟练 以及 在 何种 场景下使用哪种方法处理最优 。
小编,在最近开发中就遇到了 Array
问题, 在处理复杂的业务需求时,没想到Array
有类似的方法,然后将方法 组合起来解决当下问题。
「文章用下班时间肝了一周才写完,看完点赞、转发 是对我最大的支持。」
遍历数组方法
不会改变原数组的遍历方法
forEach()
forEach()
方法按照升序为数组中每一项执行一次给定的函数。
「语法」
arr.forEach(callback(currentValue , index , array) ,thisArg)
currentValue
: 数组当前项值index
: 数组当前项索引arr
: 数组对象本身thisArg
: 可选参数。当执行回调函数callback
时,用作this
的值。
「注意」
如果使用 「箭头函数表达式」来传入函数参数, thisArg
参数会被忽略,因为箭头函数在词法上绑定了this
值。forEach
不会直接改变调用它的对象,但是那个对象可能会被callback
函数改变。every
不会改变原数组。
//防盗贴:微信公众号: 前端自学社区
const arr = [2,3,4,1,44]
arr.forEach(val =>{
console.log(`值为${val*2}`)
})
console.log(`原数组为${arr}`);
// 值为4
// 值为6
// 值为8
// 值为2
// 值为88
// 原数组为2,3,4,1,44
reduce()
reduce()
数组元素累计器,返回一个合并的结果值。
「语法」
arr.reduce(callback(accumulator, currentValue, index, array), initialValue)
accumulator
: 累计器,默认为数组元素第一个值currentValue
: 当前值index
: 当前元素索引 可选array
: 数组 可选initialValue
: 初始值 可选
reduce
有两个参数,一个是回调函数,一个是初始值。
它有两种取值情况:
当提供了 initialValue
初始值时, 那么accumulator
的值为initialValue
,currentValue
的值为数组第一个值
当没有提供 initialValue
初始值时, 那么accumulator
的值 为 数组第一个值,currentValue
为第二个值。
「注意」
如果数组为空,且没有提供 initialValue
初始值时,会抛出TypeError
.如果数组有一个元素,且没有提供 initialValue
或者 提供了initialValue
,数组为空,那么唯一值被返回不会执行callback
回调函数。
「求和」
//防盗贴:微信公众号: 前端自学社区/
const arr = [1, 2, 3, 4]
const sum = arr.reduce((accumulator, currentValue) => accumulator + currentValue, 10)
console.log(sum) //20
// accumulator 累计器
// currentValue 当前值
// initialValue 累计 初始值 为10
//10 + 1 + 2 + 3 + 4
## 注意
// 回调函数第一次执行时,accumulator 和currentValue的取值有两种情况:
// 如果调用reduce()时提供了initialValue,accumulator取值为initialValue,currentValue取数组中的第一个值;
// 如果没有提供 initialValue,那么accumulator取数组中的第一个值,currentValue取数组中的第二个值。
「计算对象中的值」
要累加对象数组中包含的值,必须提供初始值,以便各个item正确通过你的函数。
/*
* @Description:
* @Author: 微信公众号: 前端自学社区
* @Date: 2021-08-07 00:53:51
* @LastEditTime: 2021-08-07 00:53:51
* @LastEditors: Do not edit
*/
const data = [
{
date: '2021-8-1',
income: 200
},
{
date: '2021-8-2',
income: 400
},
{
date: '2021-8-3',
income: 300
},
]
console.log(`总收入: ${data.reduce( (pre,currentValue) => pre + currentValue.income,0)}`);
//总收入: 900
「二维数组转一位数组」
const array = [[1,2],[3,4]]
console.log(array.reduce((a,b) => a.concat(b)));
//[ 1, 2, 3, 4 ]
find()
find()
返回满足特定条件的元素对象或者元素值, 不满足返回 undefined
「语法」
arr.find((element,index,array), thisArg)
element
: 当前元素index
: 当前元素索引 可选array
: 数组本身 可选thisArg
: 执行回调时用作this
的对象。 可选
// 从数据中找出第一个满足特定条件的对象
const data = [
{
name:'张三',
article: 3
},
{
name:'老王',
article: 9
},
{
name:'老李',
article: 10
}
]
console.log(data.find(item => item.article > 9 ));
// { name: '老李', article: 10 }
findIndex()
findIndex()
返回数组中符合条件的第一个元素的索引,没有,则返回 -1
。
「语法」
arr.findIndex((element,index,array), thisArg)
element
: 当前元素index
: 当前元素索引 可选array
: 数组本身 可选thisArg
: 执行回调时用作this
的对象。 可选
const arr = [22,33,44,55]
console.log(arr.findIndex(val => val > 33)); //2
console.log(arr.findIndex(val => val > 99)); //-1
key()
key()
返回一个新的「Array Iterator」对象,该对象包含数组中每个索引的键。
「语法」
keys()
「注意」
如果数组中有空原元素,在获取key 时, 也会加入遍历的队列中。
const inputModal = [
{
name:''
},
{
age:''
},
{
hobby:''
}
]
for(const key of inputModal.keys()){
console.log(key)
}
// 0
// 1
// 2
const arr = [1,2,,3]
for(const key of arr.keys()){
console.log(key);
}
// 0
// 1
// 2
// 3
//Object.keys() 方法会返回一个由一个给定对象的自身可枚举属性组成的数组
// 所以 Object.keys(arr) = [ '0', '1', '3' ]
for(const key of Object.keys(arr)){
console.log(key);
}
// 0
// 1
// 3
values()
values()
方法返回一个新的 「Array Iterator」 对象,该对象包含数组每个索引的值。
「语法」
arr.values()
const Color = ['red','yelloe','orange']
for(val of Color.values()){
console.log(val);
}
// red
// yelloe
// orange
返回 布尔值
every()
every
用来判断数组内所有元素是否符合某个条件,返回 「布尔值」
「语法」
arr.every(callback(currentValue , index , array) ,thisArg)
currentValue
: 数组当前项值 必须index
: 数组当前项索引 可选arr
: 数组对象本身可选thisArg
: 可选参数。当执行回调函数callback
时,用作this
的值。可选
「注意」
当所有的元素都符合条件才会返回 true
every
不会改变原数组。若传入一个空数组,无论如何都会返回 true
。
//防盗贴:微信公众号: 前端自学社区
const arr = [2,3,4,1,44]
console.log(arr.every(val => val > 0 )); //true
console.log(arr.every(val => { val > 2 })) //false
some()
some()
用来判断数组元素是否符合某个条件,只要有一个元素符合,那么返回 true
.
「语法」
arr.some(callback(currentValue , index , array) ,thisArg)
currentValue
: 数组当前项值 必须index
: 数组当前项索引 可选arr
: 数组对象本身可选thisArg
: 可选参数。当执行回调函数callback
时,用作this
的值。可选
「注意」
some()
被调用时不会改变数组。如果用一个空数组进行测试,在任何情况下它返回的都是 false
。some()
在遍历时,元素范围已经确定,在遍历过程中添加的元素,不会加入到遍历的序列中。
const arr = [2,3,4,1,44]
console.log(arr.some(val => val > 2)) //true
console.log([].some(val => val > 2 )); //false
const newList = [11,22,33,44]
console.log(newList.some(val => {
newList.push(55)
newList.push(66)
val > 55
})); //false
不改变原有数组,形成新的数组
filter()
filter()
用来遍历原数组,过滤拿到符合条件的数组元素,形成新的数组元素。
「语法」
arr.some(callback(currentValue , index , array) ,thisArg)
currentValue
: 数组当前项值 必须index
: 数组当前项索引 可选arr
: 数组对象本身可选thisArg
: 可选参数。当执行回调函数callback
时,用作this
的值。可选
「注意」
filter
不会改变原数组,它返回过滤后的新数组。filter()
在遍历时,元素范围已经确定,在遍历过程中添加的元素,不会加入到遍历的序列中。
const arr = [11,22,33,44,55,66]
console.log(arr.filter(val => val > 44 ))
console.log(`原数组为${arr}`);
// [ 55, 66 ]
// 原数组为11,22,33,44,55,66
map()
map()
创建一个新的数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。
「语法」
arr.map(callback(currentValue , index , array) ,thisArg)
currentValue
: 数组当前项值 必须index
: 数组当前项索引 可选arr
: 数组对象本身可选thisArg
: 可选参数。当执行回调函数callback
时,用作this
的值。可选
「注意」
map
不修改调用它的原数组本身map()
在遍历时,元素范围已经确定,在遍历过程中添加的元素,不会加入到遍历的序列中。
const arr = [1,2,3,4]
console.log(arr.map(val => val*3 )) // [ 3, 6, 9, 12 ]
console.log(arr) // [ 1, 2, 3, 4 ]
数组 CRUD
改变原数组方法
reverse()
reverse()
方法将数组中元素的位置颠倒,并返回该数组。数组的第一个元素会变成最后一个,数组的最后一个元素变成第一个。该方法会改变原数组。
const arr = [1,2,3]
console.log(arr.reverse(11,22,33)) //[ 3, 2, 1 ]
sort()
sort()
方法采用 「原地算法」进行排序并返回数组。默认排序顺序是在「将元素转换为字符串」,然后「比较它们的UTF-16
代码单元值序列」
「原地算法」是一个使用辅助的数据结构对输入进行转换的算法。但是,它允许有少量额外的存储空间来储存辅助变量。当算法运行时,输入通常会被输出覆盖。原地算法仅通过替换或交换元素来更新输入序列。
const arr = [23,11,33,44,1]
console.log(arr.sort()) //[ 1, 11, 23, 33, 44 ]
const arr = [23,11,33,44,1000000000]
console.log(arr.sort())
// [ 1000000000, 11, 23, 33, 44 ]
删除元素
shift()
shift()
方法从数组中删除「第一个」元素,并返回该元素的值。此方法更改数组的长度。
「语法」
arr.shift()
「注意」
从数组中删除的元素; 如果数组为空则返回 undefined
const data = [
{
id:1,
name:'前端'
},
{
id:2,
name:'后端'
},
{
id:3,
name:'移动端'
},
{
id:4,
name:'嵌入式开发'
},
]
const deleObj = data.shift()
console.log('==============删除后的元素======================');
console.log(data);
console.log('=================删除后的元素===================');
console.log('===============被删除的元素=====================');
console.log(deleObj);
console.log('================被删除的元素====================');
// ==============删除后的元素======================
// [
// { id: 2, name: '后端' },
// { id: 3, name: '移动端' },
// { id: 4, name: '嵌入式开发' }
// ]
// =================删除后的元素===================
// ===============被删除的元素=====================
// { id: 1, name: '前端' }
// ================被删除的元素====================
pop()
pop()
方法从数组中删除最后一个元素,并返回该元素的值。此方法更改数组的长度。
用法和 shift
类似。
「语法」
arr.pop()
「注意」
从数组中删除的元素; 如果数组为空则返回 undefined
const data = [
{
id:1,
name:'前端'
},
{
id:2,
name:'后端'
},
{
id:3,
name:'移动端'
},
{
id:4,
name:'嵌入式开发'
},
]
const deleObj = data.pop()
console.log(data);
// [
// { id: 1, name: '前端' },
// { id: 2, name: '后端' },
// { id: 3, name: '移动端' }
// ]
console.log(deleObj);
// { id: 4, name: '嵌入式开发' }
splice()
splice()
方法通过「删除」或「替换」现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容。此方法会改变原数组。
「语法」
array.splice(start,deleteCount, [item1,item2....])
start
: 开始的索引deleteCount
: 删除的个数 可选[item1,item2 .....]
;从开始的索引进行 添加的增加和替换的元素, 可选
「注意」
由被删除的元素组成的一个数组。如果只删除了一个元素,则返回只包含一个元素的数组。如果没有删除元素,则返回空数组。
如果只传递了开始的索引位置,则会删除索引后的所有元素对象
const data = [
{
id:1,
name:'前端'
},
{
id:2,
name:'后端'
},
{
id:3,
name:'移动端'
},
{
id:4,
name:'嵌入式开发'
},
]
data.splice(1)
console.log(data)
// [ { id: 1, name: '前端' } ]
「从索引为 2 开始, 删除 1 个数组元素对象,添加两个数组元素对象」
const data = [
{
id:1,
name:'前端'
},
{
id:2,
name:'后端'
},
{
id:3,
name:'移动端'
},
{
id:4,
name:'嵌入式开发'
},
]
data.splice(2,1,...[{id:5,name:'人工智能'},{id:6,name:'大数据开发'}])
console.log(data);
// [
// { id: 1, name: '前端' },
// { id: 2, name: '后端' },
// { id: 5, name: '人工智能' },
// { id: 6, name: '大数据开发' },
// { id: 4, name: '嵌入式开发' }
// ]
增加元素
splice()
上面已经有介绍
push()
push()
方法将一个或多个元素添加到数组的「末尾」,并返回该数组的新长度。
「语法」
arr.push(element1, ..., elementN)
const data = [
{
id:1,
name:'前端'
},
{
id:2,
name:'后端'
},
]
console.log(data.push({id:3,name:'移动端'})) //3
「合并数组」
const data = [
{
id:1,
name:'前端'
},
{
id:2,
name:'后端'
},
]
var obj = [
{
id:4,
name:'嵌入式开发'
},
]
// 相当于 data.push({id:4,name:'嵌入式开发'});
Array.prototype.push.apply(data, obj);
console.log(data);
[
{ id: 1, name: '前端' },
{ id: 2, name: '后端' },
{ id: 4, name: '嵌入式开发' }
]
unshift()
unshift()
方法将一个或多个元素添加到数组的「开头」,并返回该数组的「新长度」。
const arr = [1,2,3]
console.log(arr.unshift(11,22,33)) //6
console.log(arr) //[ 11, 22, 33, 1, 2, 3 ]
不改变原数组元素方法
indexOf()
indexOf()
方法返回可以在数组中找到给定元素的第一个索引,如果不存在,则返回 -1。
「语法」
indexOf(searchElement)
indexOf(searchElement, fromIndex)
searchElement
: 要查找的元素fromIndex
: 按指定的索引进行查找出现的指定元素的第一个索引。 可选如果索引大于或等于数组的长度,则返回-1 如果提供的索引值为负数,则将其视为距数组末尾的偏移量 如果提供的索引为负数,仍然从前到后搜索数组 如果提供的索引为 0,则将搜索整个数组。 默认值:0(搜索整个数组)。
const arr = [1,1,2,3,4,5,4,4,6]
console.log(arr.indexOf(3)); //3
console.log(arr.indexOf(9)); //-1
console.log(arr.indexOf(3,4)); //-1
//从索引为 4 的元素进行查找 3, 显然后面没有3 , 返回 -1
「数组去重」
创建一个新的空数组,通过indexOf
来判断空数组是否第一次存在某个元素,
不存在则返回 [ < 0 ] , push
到空数组中.
const newArr = []
arr.forEach(val => {
if(newArr.indexOf(val) < 0){
newArr.push(val)
}
})
console.log(newArr);
// [ 1, 2, 3, 4, 5, 6 ]
lastIndexOf()
lastIndexOf()
查找数组中元素最后一次出现的索引,如未找到返回-1。
如果不存在则返回 -1。从数组的后面向前查找,从 fromIndex
处开始。
「语法」
arr.lastIndexOf(searchElement, fromIndex)
searchElement
: 要查找的元素fromIndex
: 按指定的索引进行查找出现的指定元素的第一个索引。 可选从指定的索引位置 「逆向」 查找 默认为数组的长度减 1( arr.length - 1
),即整个数组都被查找。如果该值大于或等于数组的长度,则整个数组会被查找。 如果为负值,数组仍然会被从后向前查找。 如果该值为负时,其绝对值大于数组长度,则方法返回 -1,即数组不会被查找。
「注意」
lastIndexOf
使用的是 「严格相等」 === 比较searchElement
和数组中的元素。
const arr = [1,1,2,3,4,5,4,4,6]
console.log(arr.lastIndexOf(4)); //7
console.log(arr.lastIndexOf(4,11));
//7 指定的查找的索引 大于 数组的长度, 会进行整个数组查找
console.log(arr.lastIndexOf(4,-33));
// -1 指定的索引为负数,且绝对值大于数组长度, 则返回 -1
console.log(arr.lastIndexOf(4,-5));
//4 指定的索引为负数,且绝对值小于数组长度, 则会 从向前进行查找
inCludes()
includes()
方法用来判断一个数组是否包含一个指定的值,根据情况,如果包含则返回 true,否则返回false。
「语法」
arr.includes(searchElement, fromIndex)
searchElement
: 要查找的元素❝
查找时,区分大小写
❞
fromIndex
: 按指定的索引进行查找出现的指定元素的第一个索引。 可选从指定的索引进行查找 如果为负值,则按升序从 array.length + fromIndex
的索引开始搜如果 fromIndex
大于等于数组的长度,则会返回false
,且该数组不会被搜索。默认为0
const arr = [1,1,2,3,4,5,4,4,6]
console.log(arr.includes(4)); //true
console.log(arr.includes(4,66)); //false
console.log(arr.includes(1,-1)); //false
concat()
concat()
方法用于合并两个或多个数组。
「语法」
var new_array = old_array.concat([arr1][arr2])
「注意」
concat
方法不会改变this
或任何作为参数提供的数组,而是返回一个「浅拷贝」,它包含与原始数组相结合的相同元素的副本❝
对象引用(而不是实际对象): concat
将对象引用复制到新数组中。 原始数组和新数组都引用相同的对象。 也就是说,如果引用的对象被修改,则更改对于新数组和原始数组都是可见的。 这包括也是数组的数组参数的元素。数据类型如字符串,数字和布尔(不是 String
,Number
和Boolean
) 对象):concat
将字符串和数字的值复制到新数组中。
❞
let arr1 = [1,2,3]
let arr2 = [4,5,6]
let arr3 = [[1,2],[3,4]]
console.log(arr1.concat(arr2));
//[ 1, 2, 3, 4, 5, 6 ]
// 嵌套合并
console.log(arr1.concat(arr2).concat(arr3));
// [ 1, 2, 3, 4, 5, 6, [ 1, 2 ], [ 3, 4 ] ]
let obj1 = [{a:1},{b:2}]
let obj2 = [{c:3},{d:4}]
let obj3 = obj1.concat(obj2)
console.log(obj3);
//[ { a: 1 }, { b: 2 }, { c: 3 }, { d: 4 } ]
obj1[0].a = 4 //改变obj[0]对象值,会直接影响合并后的数组,因为是浅拷贝
console.log(obj3);
//[ { a: 4 }, { b: 2 }, { c: 3 }, { d: 4 } ]
toString()
toString()
返回一个字符串,表示指定的数组及其元素。
「当一个数组被作为文本值或者进行字符串连接操作时,将会自动调用其 toString
方法。」
对于数组对象,toString
方法连接数组并返回一个字符串,其中包含用逗号分隔的每个数组元素。
「语法」
arr.toString()
const arr = [1,2,3]
console.log(arr.toString()); //1,2,3
join()
join()
方法通过连接数组元素用逗号或指定的分隔符字符串分隔,返回一个字符串。
如果数组只有一项,则将在不使用分隔符的情况下返回该项。
「语法」
join()
join(separator)
separator
: 指定的分割的 字符 可选
const arr = ['2021','08','08']
console.log(arr.join()); //2021,08,08
console.log(arr.join('-')); //2021-08-08
console.log(arr.join('/')); //2021/08/08
slice()
slice()
方法返回一个新的数组对象,这一对象是一个由 begin
和 end
决定的原数组的「浅拷贝」(包括 begin
,不包括end
)。原始数组不会被改变。
「语法」
arr.slice(begin, end)
begin
: 指定截取的「开始」索引 可选❝
默认从0 开始 如果 begin
为负数,则以数组末尾开始 的 绝对值开始截取slice(-2)
末尾第2个元素如果 begin
超出原数组的索引范围,则会返回空数组。
❞
end
: 指定截取的「结束」索引 可选❝
如果 end
被省略,则slice
会一直提取到原数组末尾。如果 end
大于数组的长度,slice
也会一直提取到原数组末尾。如果 end
为负数, 则它表示在原数组中的倒数第几个元素结束抽取。
❞
const arr = [11,22,33,44,55,66,77,88]
console.log(arr.slice(1,4));
// 应该返回 索引 1 - 3 的数组元素
// [ 22, 33, 44 ]
console.log(arr.slice(-4,2)) //[]
console.log(arr.slice(-4)); //[ 55, 66, 77, 88 ]
console.log(arr.slice(0,-1));
// [
// 11, 22, 33, 44,
// 55, 66, 77
// ]
参考文献
最后
文章用下班时间肝了一周,写作不易,文中的内容都是 参考 MDN 文档 。
如果喜欢的话可以点赞关注,支持一下,希望大家可以看完本文有所收获 !
最全总结 JavaScript Array 方法详解的更多相关文章
- JavaScript数组方法详解
JavaScript数组方法详解 JavaScript中数组的方法种类众多,在ES3-ES7不同版本时期都有新方法:并且数组的方法还有原型方法和从object继承的方法,这里我们只介绍数组在每个版本中 ...
- JavaScript中数组Array方法详解
ECMAScript 3在Array.prototype中定义了一些很有用的操作数组的函数,这意味着这些函数作为任何数组的方法都是可用的. 1.Array.join()方法 Array.join()方 ...
- javascript Array数组详解 各种方法
1.数组的声明方法(1): arrayObj = new Array(); //创建一个数组.复制代码 代码如下: var arr1 = new Array(); (2):arrayObj = new ...
- 深入学习JavaScript: apply 方法 详解(转)——非常好
主要我是要解决一下几个问题: 1. apply和call的区别在哪里 2. 什么情况下用apply,什么情况下用call 3. apply的其他巧妙用法(一般 ...
- JavaScript: apply 方法 详解(转)——非常好
转载自 http://www.cnblogs.com/KeenLeung/archive/2012/11/19/2778229.html 我在一开始看到javascript的函数apply和call ...
- 深入学习JavaScript: apply 方法 详解
我在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这里我做如下笔记,希望和大家 ...
- JavaScript sort() 方法详解
定义和用法 sort() 方法用于对数组的元素进行排序. 语法 arrayObject.sort(sortby) 参数 描述 sortby 可选.规定排序顺序.必须是函数. 返回值 对数组的引用.请注 ...
- JavaScript indexOf() 方法详解
定义和用法 indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置. 语法 stringObject.indexOf(searchvalue,fromindex) 参数 描述 sea ...
- JavaScript进阶(十)Array 数组详解
JS array 数组详解 数组的声明方法 arrayObj = new Array(); 的数组 ,并且第一位是5 数组的运算(传地址) var t2=new Array(); t2[0]=1; t ...
随机推荐
- python-geopandas读取、创建shapefile文件
作者:fungis 描述:一个热带生活.乐于分享.努力搬砖的giser 交流邮箱:fungis@163.com shapefile是GIS中非常重要的一种数据类型,在ArcGIS中被称为要素类(Fea ...
- 密码学系列之:twofish对称密钥分组算法
简介 之前的文章我们讲到blowfish算法因为每次加密的块比较小只有64bits,所以不建议使用blowfish加密超过4G的文件.同时因为加密块小还会导致生日攻击等.所以才有了blowfish的继 ...
- CVPR2021 | 开放世界的目标检测
本文将介绍一篇很有意思的论文,该方向比较新,故本文保留了较多论文中的设计思路,背景知识等相关内容. 前言: 人类具有识别环境中未知对象实例的本能.当相应的知识最终可用时,对这些未知实例的内在好奇心 ...
- python使用venv
venv模块支持使用自己的站点目录创建轻量级"虚拟环境",可选择与系统站点目录隔离.每个虚拟环境都有自己的Python二进制文件(与用于创建此环境的二进制文件的版本相匹配),并且可 ...
- 6、安装kvm虚拟机
6.1.虚拟机开启虚拟化: 6.2.检查linux虚拟机cpu是否开启了虚拟化: egrep -o 'vmx|svm' /proc/cpuinfo vmx 6.3.安装kvm管理和安装kvm虚拟机的软 ...
- Linux系统下安装NodeJS
下载NodeJS二进制压缩包 去NodeJS官网https://nodejs.org/zh-cn/,下载二进制压缩包,进入下载页面之后你将看到很多下载选项: 源码不包含bin目录,不是可运行的应用程序 ...
- 低代码Paas开发平台可以本地实施吗
低代码Paas开发平台可以本地实施吗?答案是肯定的.虽然低代码开发通常是以云端形式面向用户,也就是我们经常看到到aPaaS,而它也更加倾向于SaaS.但实际上,低代码开发平台是可以支持本地部署的,例如 ...
- Dubbo:dubbo管理界面安装
首先需要Tomcat.Zookeeper安装后在进行安装Dubbo管理界面 提供Dubbo-admin管理界面war包: https://github.com/zhaoyue123ABC/Publi ...
- redis广播/订阅模式演示
参考博客 http://www.pianshen.com/article/7183315879/ 1.首先在本地启动redis服务 2.启动4个客户端 redis-cli 3.将其中三个客户端设置监听 ...
- 【重学Java】多线程进阶(线程池、原子性、并发工具类)
线程池 线程状态介绍 当线程被创建并启动以后,它既不是一启动就进入了执行状态,也不是一直处于执行状态.线程对象在不同的时期有不同的状态.那么Java中的线程存在哪几种状态呢?Java中的线程 状态被定 ...