Skip to content

Latest commit

 

History

History
224 lines (164 loc) · 6.27 KB

javascript-solutions.md

File metadata and controls

224 lines (164 loc) · 6.27 KB

JavaScript exercises solutions

Fill the missing bits

Functions as arguments

Open in CodePen

// Let's define a couple of arithmetic function.
function add(a, b) {
  return a + b;
}
function multiply(a, b) {
  return a * b;
}

// Define a function that takes two numbers
// and a function to apply to those numbers.
function compute(a, b, func) {
  return func(a, b);
}

// Call compute with "add".
let value = compute(2, 4, add);
console.log(value); // 6

// Call compute with "multiply".
value = compute(2, 4, multiply);
console.log(value); // 8

Dynamically create functions

Open in CodePen

// Implement this function in a way that makes the rest of the code work.
function createMultiplier(factor) {
  return number => number * factor;
}

const multiplyByTwo = createMultiplier(2);
console.log(multiplyByTwo(1)); // 2
console.log(multiplyByTwo(2)); // 4
console.log(multiplyByTwo(3)); // 6

const multiplyByFive = createMultiplier(5);
console.log(multiplyByFive(1)); // 5
console.log(multiplyByFive(2)); // 10
console.log(multiplyByFive(3)); // 15

This type of function is called a closure.

Open in CodePen

const personJson = '{"first":"James","last":"Bond"}';

// Extract the person's first and last names to new variables
// to make this code work, without modifying the rest of the code.
const { first, last } = JSON.parse(personJson);

console.log(`My name is ${last}, ${first}, ${last}`);

ECMAScript 2015+

Open in CodePen

const firstName = 'John';
const lastName = 'Doe';

// Use a template literal instead of string concatenation.
console.log(`Hello, I am ${firstName} ${lastName}!`);

Open in CodePen

const people = [
  { first: "John", last: "Doe" },
  { first: "Bob", last: "Martin" },
  { first: "Alice", last: "Krauss" }
];

// Convert this function to an arrow function and save 2 lines.
const lastNames = people.map(person => person.last);

console.log(lastNames); // [ "Doe", "Martin", "Krauss" ]

Open in CodePen

let fruits = [ 'apple', 'pear', 'lemon' ];

// Use a for...of loop instead of iterating with an index.
for (let fruit of fruits) {
  console.log(`${fruit} is a fruit`);
}

Open in CodePen

const values = [ 23, 61, 42, 51, 12 ];

// Use a destructuring assignment to convert the next 2 lines
// to a single expression without modifying the rest of the code.
const [ firstValue, ...otherValues ] = values;

console.log(`The first value is ${firstValue}`);
console.log(`The other values are ${otherValues.join(', ')}`);

Open in CodePen

const person = {
  first: 'John',
  last: 'Doe',
  address: {
    city: 'Yverdon',
    street: 'Avenue des Sports',
    zip: 1400
  }
};

function logHabitation({ first, address: { city }}) {
  // Use a destructuring assignment in the function's argument to
  // remove the next 2 lines, without modifying the console.log statement.
  console.log(`${first} lives in ${city}`);
}

logHabitation(person); // "John lives in Yverdon"

Open in CodePen

const bob = {
  name: 'Bob',
  address: null
};

const alice = {
  name: 'Alice',
  address: {
    poBox: '000'
  }
};

const chuck = {
  name: 'Chuck',
  address: {
    city: 'Dallas'
  }
}

// Simplify this function using optional chaining and the nullish coalescing
// operator.
function whereDoTheyLive(person) {
  return person?.address?.city ?? 'Unknown';
}

console.log(whereDoTheyLive(bob));    // "Unknown"
console.log(whereDoTheyLive(alice));  // "Unknown"
console.log(whereDoTheyLive(chuck));  // "Dallas"

Open in CodePen

advise();

// Get rid of the .then calls and callback functions by using async/await.
async function advise() {
  const res = await fetch('https://api.adviceslip.com/advice');
  const { slip: { advice } } = await res.json();
  console.log(advice);
}