Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

JavaScript Build a Simple Dynamic Site with Node.js Creating a Basic Template Engine in Node.js A Simple Merge Utility

Lanre TH
Lanre TH
1,037 Points

Complete the implementation of the merge method in utilities.js file. You should be able to pass in a string with placeh

I don't understand, its not working

index.js
var utilities = require("./utilities");

var mailValues = {};

mailValues.first_name = "Janet";

var emailTemplate = "Hi %first_name%! Thanks for completing this code challenge :)";

var mergedContent = utilities.merge(emailTemplate, mailValues);

//mergedContent === "Hi Janet! Thanks for completing this code challenge :)";
utilities.js
function merge(content, values) {
    for (var key in content){
          content = content.replace("%key%",values);
    }
  return content;
}


module.exports.merge = merge;

8 Answers

Clinton Johnson
Clinton Johnson
28,714 Points

function merge(content, values) { for(var key in values) { content = content.replace('%'+key+'%', values[key]); } return content; } // So to piggy back off of Steven Parker you want to put values[key] because it is an object literal of an array which means that the function merge will loop through the values of the key -> values[key] <- thats what this line of code means. Just remember that you have to specify everything to the t in order for the computer to read your line of code properly and in this case think of it like this if you leave the values empty <- Then your are not specifying in particular where you want the computer to get the values from, hence placing this -> [key] next to value is telling the computer to look in the key and retrieve the values from there. Sorry if i was longwinded hope this helps.

Steven Parker
Steven Parker
232,161 Points

:point_right: You're getting close, but you have a few issues yet:

  • the content is the string you're replacing in — you'll want to loop through the values
  • instead of the word "key", you'll need to concatenate the actual key between two percent signs
  • you'll want to replace the match string with the specific value associated with that key
Lanre TH
Lanre TH
1,037 Points

function merge(content, values) { for (var key in content){ content = content.replace("Hi %"+key+"%! Thanks for completing this code challenge :)",values); } return content; }

module.exports.merge = merge;

Steven Parker

Lanre TH
Lanre TH
1,037 Points

I am not still getting it, please I need you help Steven Parker

Steven Parker
Steven Parker
232,161 Points

What does your code look like after you apply the 3 hints I gave you above?

Steven Parker
Steven Parker
232,161 Points

It looks like you only implemented one of the three hints.

Plus you got the concatenation right, but you added some extra words to the replacement string that are not part of the challenge. Lets look at the other two hints again (and a new one) in the context of the code:

  for (var key in content)   :point_left: you'll want to loop through the values (not the content)

    "Hi %"+key+"%! Thanks for completing this code challenge :)"   :point_left: don't add anything to the content

    ...content.replace("%"+key+"%", values);   :point_left: replace using the specific value associated with the key
Remember, values is a complex object but you can use the key as an index to get a specific value from it.

If any of these hints are still not clear, I strongly suggest re-watching the video on Binding Values. It walks you through a task very similar to this one.

function merge(content, values) { for(var key in values){ content = content.replace("{{"%" + key + "%"}}", values[key]); } return content; }

module.exports.merge = merge;

I read all comments but still I am having same errors , please steve parker help me

catarinabrendel
catarinabrendel
11,898 Points

Khumoyunmirzo Nosirov you need to remove the curly brackets. In the code provided it uses the '%' symbol to indicate the values to be removed and not the '}' symbol.

content.replace("{{"%" + key + "%"}}", values[key]); <-- specifically in this line

Adem Krasniqi
Adem Krasniqi
7,967 Points

This is what worked for me, taken from another community answer to this challenge:

function merge(content, values) {
  for (key in values) {
    content = content.replace("%"+key+"%", values[key]);
  }
  return content;
}

module.exports.merge = merge;