JavaScript Objects

JavaScript Objects

·

5 min read


The object data type is the 8th data type and only the non-primitive data type. In this article, we will see how to create and access objects in JavaScript.


How to create an object

Objects are created with curly brackets containing properties, { ... }.

Empty objects are objects with no property list.

A property is a "key": value pair. Keys are in quotes if it is multi-word but without quotes if in a single word. The values are anything. The key is also called name and value, identifier.

Note: It is a good practice to use the camelCase naming convention for keys, myName, not my name.

See the below syntax:

obj = { key1: value1, key2: value2, ..., keyN: valueN }

The syntax above is called object literal syntax

See the example below:

const person = { 
    myName: "John Doe", 
    age: 34,
    isDoctor: true
}

Property names are always in strings even though not specified. That is, age property is the same as "age".

When you write object properties in multiple lines, as shown above, it is called the trailing or hanging comma.

Every box (object) has keys to access specific items (values).

An empty object can also be filled by appending properties to it.

const person= {};

person.name = "John Doe";
person.age= 34;
person.isDoctor= true

To create a new object, the syntax is shown below:

obj = new Object();

Accessing Keys

There are two ways to access key properties in JavaScript, they are:

  • Dot notation
  • Square bracket

Dot Notation

See the example below on how to access the value, 34:

const person = { 
    "my name": "John Doe", 
    age: 34,
    isDoctor: true
}

person.age; // 34 => dot notation

person.age accessed the value, 34 through dot notation


Square brackets

The dot notation doesn't work when keys contain special characters like space.

const person = { 
    age: 34,
    isDoctor: true
}

person["my name"] = "John Doe";

console.log(person); 
// { age: 34, isDoctor: true, 'my name': 'John Doe' }

person["my name"]; // John Doe => square brackets notation

Computed Properties

Square brackets can be used in an object literal also to create object properties. Such properties are called computed properties.

See the example below:

const name = "myName" ;

const person = { 
    [name]: "John Doe",
    age: 34,
    isDoctor: true
}

console.log(person.myName);  // John Doe

Object in a function

We can also have a function nesting object(s). The example above is similar to the code below but with a better style. The advantage of the code below is that the object is now locally scoped in the function (to avoid scope pollution).

const personDetails = name => {
  const person = {
    name: name,
    age: 34,
    isDoctor: true
  };

  return person;
};

const p = personDetails("John Doe");

console.log(p.name); // John Doe


Property Value Shorthand

It is also possible to use as many variables (and parameters) as values for property names (keys).

const personDetails = (name, age, isDoctor) => {
  return {
    name: name,
    age: age,
    isDoctor: isDoctor
  };
};

const person = personDetails("John Doe", 34, true);

console.log(person.name); // John Doe
console.log(person.age); // 34
console.log(person.isDoctor); // true

It is common to use special property value shorthand. The function personDetails() above is called factory function. Factory function allows the creation of similar objects.

Instead of name:name, age:age, isDoctor:isDoctor we can just write name, age, isDoctor respectively.

const personDetails = (name, age, isDoctor) => {
  return {
    name,
    age,
    isDoctor
  };
};

const person = personDetails("John Doe", 34, true);

console.log(person.name);

Both normal and shorthand properties can be in the same object.

const personDetails = (age, isDoctor) => {
  return {
    name: "John Doe",
    age,
    isDoctor
  };
};

const person = personDetails(34, true);

console.log(person.name);

Alternatively declare the obj before returning it.

const personDetails = (age, isDoctor) => {

  const obj = {
    name: "John Doe",
    age,
    isDoctor
  };

  return obj;
};

const person = personDetails(34, true);

console.log(person.name);

Undefined properties

Accessing property values that do not exist in an object returns undefined.

const person = { 
    age: 34,
    isDoctor: true
}

console.log(person.name); // undefined

Property existence test

Properties can be tested for existence.

const person = { 
    age: 34,
    isDoctor: true
}

person.name === undefined; // true

Alternatively, properties can be tested for existence by the special operator in.

The example above is the same as below:

const person = { 
    age: 34,
    isDoctor: true
}

"name" in person; // false

Here is another example

const person = { 
    name: undefined,
    age: 34,
    isDoctor: true
}

"name" in person; // true

The result fails if person.name is used.

See example below:

const person = { 
    name: undefined,
    age: 34,
    isDoctor: true
}

person.name; // undefined

Looping through Objects

To loop through object keys or values, the for...in syntax is used.

for (key in object) {
  // statements to loop through keys
}

See the example below:

const person = { 
    yourName: "John Doe", 
    age: 34,
    isDoctor: true
};

for (let key in person) {
    // keys
    console.log(key);  // yourName, age, isDoctor

    // values for the keys
    console.log(person[key]); // John Doe, 34, true
}

Ordered Objects

Objects are sorted if the keys are integers

See the example below:

const person = { 
    "20": "John Doe", 
    "1": 34,
    "3": true
};

for (let key in person) {
    // keys
    console.log(key);  // 1, 3, 20

    // values for the keys
    console.log(person[key]); // 34, true, John Doe
}

The ordering above does not work for non-integer keys or decimal number keys.

const person = { 
    "+1": "John Doe", 
    "2.0": 34,
    "bool": true
};

for (let key in person) {
    // keys
    console.log(key);  // +1, 2.0, bool

    // values for the keys
    console.log(person[key]); // John Doe, 34, true
}

Happy coding!


Buy me a Coffee


TechStack | Domain

  • Purchase a .com domain name as low as $9.99.
  • Purchase a .net domain name as low as $12.99.
  • Get cheaper domain names as low as $3.
  • Build a website with ease.