Reputation: 1779
I could use some guidance on specifying a dynamic multi dimensional array in javascript. I understand that javascript does not natively define multi dim arrays, but rather an array of an array, ie.
var items = [[1,2],[3,4],[5,6]];
or
var array = [[,],[,]]
or
var a = [[1,2],[3,4]]
My issue is that I do not know the actual dimensions, and simply defining the array, as in the second example above, still does not allow for the array to go beyond two record sets. I thought there was a REDIM stmt similar to VB but have not been able to locate anything.
One additional part of my problem is that when I specify the second dimension of the array, as in the example below, the array becomes unreachable outside of the for block.
var Exforsys=new Array(4)
for (i=0; i <4; i++) {
Exforsys[i]=new Array(4)
}
I am trying to retrieve data from my specific array like this...
function newTest() {
var myArray = [[],[]];
// myArray[] = new Array(14);
var recCount = coordsAry.length / 15;
var n =0;
var i = 0;
var s = 0;
for (i = 0; i < recCount; i++) {
for (s = 0; s < 15; s++) {
// myArray[i] = new Array(14);
myArray[i][s] = coordsAry[n];
n++;
// alert("i=" + i + " s=" + s + " Val: " + (myArray[i][s]));
}
// var u = 4;
s = 0;
alert(myArray[0][3]);
alert(myArray[0][4]);
alert("i=" + i + " s=" + s + " Val: " + (myArray[i][s]));
}
coordsAry has 105 records and is flat, {"12","Frank","564", ... etc} this has been proven. After the 2nd record is populated I get this error....
Error: Unable to set value of the property '0': object is null or undefined.
Obviously, my javascript skills are a bit rough to say the least. Any sample code would be greatly appreciated.
Thanks,
Upvotes: 16
Views: 67578
Reputation: 1
var rows = 4;
var cols = 3;
const mulDimArray = Array.from(
new Array(rows)
.fill(0), ele => ele =
new Array(cols).fill(0)
)
console.log(mulDimArray);
Upvotes: 0
Reputation: 488
Lately, I've been using this syntax for creating a two-dimensional array of fixed rows and columns.
Create 2d array:
new Array(rows).fill(0).map(_ => new Array(cols))
Create 2d array and populate with default value:
new Array(rows).fill(0).map(_ => new Array(cols).fill(0))
Details:
rows
by doing - new Array(rows)
..fill(0)
. This step is needed because the JavaScript array's map method doesn't iterate over empty values..map(_ => new Array(cols))
.Upvotes: 2
Reputation: 8621
You do not Dim the Array to an actual size,
You can just set an variable on any index to whatever you want
if you want two Dimensions you just could define an array
var arr = []
set an element to another array
arr[0] = []
and put an value inside an element in the "2nd dimension"
arr[0][10] = 10
You only have the elements in the "first dimension" to be an array
You could also do things like placing arrays into arrays
like
var arr = []
var arr1 = [1,2,3]
arr[0] = arr1
console.log(arr[0][2]) //3
And if you have an array and want to push elements in an inner array just do a check if the element is defined, like
var arr = []
for ( var i = 0; i < 5 ; i++) {
if(!arr[i])
arr[i] = []
for ( var j = 0; j < 3 ; j++)
arr[i][j] = i + " - " + j // Or like this,
//arr[i].push(i + " " + j) //
}
console.log( arr[2][3]) // 2 - 3
function newTest() {
var myArray = [[],[]];
// myArray[] = new Array(14);
var recCount = 15
var n =0;
var i = 0;
var s = 0;
for (i = 0; i < recCount; i++) {
if(!myArray[i])
myArray[i] = []
for (s = 0; s < 15; s++) {
console.log(i)
// myArray[i] = new Array(14);
myArray[i][s] = s;
n++;
// alert("i=" + i + " s=" + s + " Val: " + (myArray[i][s]));
}
// var u = 4;
s = 0;
alert(myArray[0][3]);
alert(myArray[0][4]);
alert("i=" + i + " s=" + s + " Val: " + (myArray[i][s]));
}
}
newTest()
This works for me
Upvotes: 23
Reputation: 2942
All arrays are dynamic in javascript. You can do things like
var list = [];
list[15] = 15;
And it will simply expand the array to have a length of 16, with the values for the first 15 indexes being undefined (~ null). Thus, your 3 examples of multi-dimensional arrays should all work.
Edit: Just saw that you included your code. You are not initializing the arrays of your first dimension. Your loop should be
for (i = 0; i < recCount; i++) {
//If the outer array does not have an inner array at this position already, create one
if (!myArray[i])
myArray[i] = []; //!!!
for (s = 0; s < 15; s++) {
// myArray[i] = new Array(14);
myArray[i][s] = coordsAry[n]; //myArray[i] returned null/undefined, when i got bigger then the declared array.
n++;
// alert("i=" + i + " s=" + s + " Val: " + (myArray[i][s]));
}
// var u = 4;
s = 0;
alert(myArray[0][3]);
alert(myArray[0][4]);
alert("i=" + i + " s=" + s + " Val: " + (myArray[i][s]));
}
Upvotes: 3
Reputation: 874
To add an element to an array you can use push(val) (to add the back of the array) or unshift(val) to add to the front of the array. So:
var Exforsys=[];
for (i=0; i <4; i++) {
Exforsys.push([]);
}
Upvotes: 0