-
Notifications
You must be signed in to change notification settings - Fork 238
/
Copy patharray-slice-splice.js
161 lines (121 loc) · 4.78 KB
/
array-slice-splice.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
/**
* Array slice() vs splice()
*
* 1. The splice() method returns the removed item(s) in an array and slice() method returns the selected element(s) in an array, as a new array object.
*
* 2. The splice() method changes the original array and slice() method doesn’t change the original array.
*
* 3. The splice() method can take n number of arguments:
* Argument 1: Index, Required. An integer that specifies at what position to add /remove items, Use negative values to specify the position from the end of the array.
* Argument 2: Optional. The number of items to be removed. If set to 0(zero), no items will be removed. And if not passed, all item(s) from provided index will be removed.
* Argument 3…n: Optional. The new item(s) to be added to the array.
*
* 4. The slice() method can take 2 arguments:
* Argument 1: Required. An integer that specifies where to start the selection (The first element has an index of 0). Use negative numbers to select from the end of an array. If this is undefined, slice begins from index 0
* Argument 2: Optional. An integer that specifies where to end the selection. If omitted, all elements from the start position and to the end of the array will be selected. Use negative numbers to select from the end of an array.
*
* @Reference:
* http://www.tothenew.com/blog/javascript-splice-vs-slice/
*/
// Array.splice()
// Format: array.splice(start, deleteCount[, item1[, item2[, ...]]])
var array = [1, 2, 3, 4, 5];
console.log(array.splice(2));
// shows [3, 4, 5], returned removed item(s) as a new array object.
console.log(array);
// shows [1, 2], original array altered.
var array2 = [6, 7, 8, 9, 0];
console.log(array2.splice(2, 1));
// shows [8]
console.log(array2.splice(2, 0));
//shows [] , as no item(s) removed.
console.log(array2);
// shows [6,7,9,0]
var array3 = [11, 12, 13, 14, 15];
console.log(array3.splice(2, 1, "Hello", "World"));
// shows [13]
console.log(array3);
// shows [11, 12, "Hello", "World", 14, 15]
// -6 -5 -4 -3 -2 -1
// | | | | | |
var array4 = [16, 17, 18, 19, 20];
// | | | | | |
// 0 1 2 3 4 5
console.log(array4.splice(-2, 1, "me"));
// shows [19]
console.log(array4);
// shows [16, 17, 18, "me", 20]
// If Argument(1) is NaN, it is treated as if it were 0.
var array5 = [21, 22, 23, 24, 25];
console.log(array5.splice(NaN, 4, "NaN is Treated as 0"));
// shows [21,22,23,24]
console.log(array5);
// shows ["NaN is Treated as 0",25]
// If 2nd argument is less than 0 or equal to NaN, it is treated as if it were 0.
var array6 = [26, 27, 28, 29, 30];
console.log(array6.splice(2, -5, "Hello"));
// shows []
console.log(array6);
// shows [26,27,"Hello",28,29,30]
console.log(array6.splice(3, NaN, "World"));
// shows []
console.log(array6);
// shows [26,27,"Hello","World",28,29,30]
// If Argument(1) or Argument(2) is greater than Array’s length, either argument will use the Array’s length.
var array7 = [31, 32, 33, 34, 35];
console.log(array7.splice(23, 3, "Add Me"));
// shows []
console.log(array7);
// shows [31,32,33,34,35,"Add Me"]
console.log(array7.splice(2, 34, "Add Me Too"));
// shows [33,34,35,"Add Me"]
console.log(array7);
// shows [31,32,"Add Me Too"]
// The slice() method can take 2 arguments:
// arr.slice([begin[, end]])
// slice extracts up to but not including end argument.
var fruits = ['Banana', 'Orange', 'Lemon', 'Apple', 'Mango'];
var citrus = fruits.slice(1, 3);
// citrus contains ['Orange','Lemon']
var array = [1, 2, 3, 4, 5];
console.log(array.slice(2));
// shows [3, 4, 5], returned selected element(s).
console.log(array.slice(-2));
// shows [4, 5], returned selected element(s).
console.log(array);
// shows [1, 2, 3, 4, 5], original array remains intact.
var array2 = [6, 7, 8, 9, 0];
console.log(array2.slice(2, 4));
// shows [8, 9]
console.log(array2.slice(-2, 4));
// shows [9]
console.log(array2.slice(-3, -1));
// shows [8, 9]
console.log(array2);
// shows [6, 7, 8, 9, 0]
// If either argument is NaN, it is treated as if it were 0.
var array3 = [11, 12, 13, 14, 15];
console.log(array3.slice(NaN, NaN));
// shows []
console.log(array3.slice(NaN, 4));
// shows [11,12,13,14]
console.log(array3);
// shows [11,12,13,14,15]
// If either argument is greater than the Array’s length, either argument will use the Array’s length
var array4 = [16, 17, 18, 19, 20];
console.log(array4.slice(23, 24));
// shows []
console.log(array4.slice(23, 2));
// shows []
console.log(array4.slice(2, 23));
// shows [18,19,20]
console.log(array4);
// shows [16,17,18,19,20]
// If begin is undefined slice starts from 0
var array5 = [21, 22, 23, 24, 25];
console.log(array5.slice(undefined, 2));
// shows [21, 22]
//slice can be used to copy an array by ommiting both begin and end
var array6 = array5.slice();
console.log(array6);
//shows [21, 22, 23, 24, 25]