Arrays and strings in JavaScript. Basics part 5 — summary.

JavaScript file

After discussing the absolute basics, it’s time to talk about arrays and strings in JavaScript. These are really important elements, and having mastered them we are ready to go to the next level.

Arrays and strings in JavaScript

At first we’ll take a look at text strings and basic methods of processing them. Afterwards we’ll discuss the arrays.

Personally I really like coding something related with strings and/or arrays.

The text is supported by the String class (type). This class allows us to create objects that contain strings; chars and subtitles. Also provides a lot of methods to operate on these strings:

anchorreplace
bigsearch
blinkslice
boldsmall
charAtsplit
charCodeAtstrike
concatsub
fixedsubstr
fontcolorsubstring
fontsizesup
indexOftoLowerCase
italicstoSource
lastIndexOftoUpperCase
linktoString
matchvalueOf

Example — working with strings:

var str = new String("Hi JavaScript!");
document.writeln("Our string: " + str.italics() + " has "
    + str.length + "chars length");

Using the dot operator we call the method of the String class, associated with our object (string).

The + operator is used to connect the strings. Of course in the context of String type. For the numbers it’s just operation of summation.

Example — split the string by a separator:

var tab = "ab-cd-ef-gh".split("-");
for (index in tab) {
    document.write(tab[index] + "<br />");
}

For example, such effect in PHP is reachable by the explode() function.

Example — operations on a string (then anchor method):

var str = new String("abc");
// puts str to the <a> markup:
// <a name="myname">abc</a>
var str = "abc".anchor("myname");

Methods for processing strings

Below we described frequently used methods of the String class:

charAt — returns the character located within the index specified by the argument:

var c = "abc".charAt(1);

charCodeAt — returns the character code:

var code = "abc".charCodeAt(1);

concat — string concatenation:

var str1 = "A"; var str2 = "B";
var str3 = "123".concat(str1, str2); // result: 123AB

fromCharCode — returns a string made ​​of the characters whose numeric codes were passed as arguments:

var str = String.fromCharCode(65, 66, 67);

indexOf  — returns the index (position) of a character or substring; the second argument determines the starting point (index), if not specified then the default value (0) is used:

var index = "abcabcabc".indexOf("bc");

lastIndexOf  — the same as indexOf, but string is searched from the end:

var index = "abcabcabc".lastIndexOf("bc"); // result: 7

replace — replacing part of the string:

var str = "John has a cat. John also knows JavaScript.";
var str2 = str.replace(/John/gi, "Ben"); // regular expression

In this case we swapped John with Ben.

search — checks whether a string described by the regular expression (regExp variable) occurs within a string:

myString.search(regExp);

slice — returns a slice of the string, first parameter is the point of start, the second (optional) — the stopping point:

var str1 = "abcdefg".slice(3);
var str2 = "abcdefg".slice(3, 5);

valueOf — returns a basic value stored by an object. In case of text string it’s the same as string.toString(), and returns the string contained in the object.

More about regular expressions we will write in next, more detailed article.

Arrays in JavaScript

To create and operate on arrays there is a “class” named Array.

Methods of the Array class:

concatslice
joinsort
popsplice
pushtoString
reverseunshift
shiftvalueOf

Example — increase the length of an array (indirect):

var tab = new Array();
tab[100] = 1;

Example — using the join() method:

var str = tab.join(',');

The join() method will return a string built from the array elements separated by separator (here: the comma).

The same as for strings, we can use the length property, which informs us about the number of elements in our array:

var tab = new Array();
tab.push(1,2);
alert(tab.length);

Example — array sorting:

var tab = new Array('PHP', 'Ada', 'JavaScript', 'Ruby');
tab.sort();
alert(tab.join()); // Ada,JavaScript,PHP,Ruby

This is obviously a very simple example of sorting.

The definition of arrays — may be done in different ways:

var t = new Array("a","b","c");

can be written in a concise form:

Rent A Car paralimni

var t = ["a","b","c"];

We can easily add and remove items to the array (an object of the Array class). For this we have push() and pop() methods.

// add element(s) at the end of an array:
tab.push(element1[, element2, …, elementN]);

// return the last element
tab.pop();

splice — removes elements from an array (new ones can be inserted in their place):

// removing elements
splice(index, howMuch, [element1][, …, elementN]);

Example:

var tab1 = new Array("a", "b", 0, 0 , 0, "f", "g");

// will remove 3 elements, starting from index of 2
// and will put new elements (c, d, e) instead:
tab1.splice(2, 3, "c", "d", "e");

The Array class also contains the shift() and unshift() methods, which are similar to push() and pop(). The main difference is that they operate at the beginning of array, not at the end.

Generally elements of an array can be removed through:

splice method — the result will be a new array, without unnecessary elements:

// removes 5 elements
var newTab = tab.splice(1, 5);

delete operator:

delete tab[index];

Additional examples of work with the Array class you can find here: w3schools.

2-D arrays in JavaScript

In JavaScript, we can also use multidimensional arrays. We show how this can be done.

Example — 2D array — matrix:

str = "Matrix ";
var a = new Array(4); // crating new array with N elements
for (i = 0; i < 4; i++) {
    a[i] = new Array(4);
    for (j = 0; j < 4; j++) {
        a[i][j] = "[" + i + ", " + j + "]";
    }
}

// processing and legibly printing of 2D array
for (i = 0; i < 4; i++) {
    s = "Row " + i + ":";
    for (j = 0; j < 4; j++) {
        s += a[i][j];
    }
    str += s + " | ";
}
alert(str);

Another way to define a multidimensional array in JavaScript:

var matrix = [
    [0, 1, 2],
    [3, 4, 5],
    [6, 7, 8]
];
alert(matrix[2][1]); // 7

And with this example we finish a brief statement of arrays and strings in JavaScript, thus discussing basics of the language.

Summary

We already have a solid base to explore more serious and interesting issues of the JS language.

Constructive comments are welcome.

In the next article we will work with DOM (Document Object Model) in JavaScript. We won’t forget also about BOM (Browser Object Model).

Thank you.