Tagged Template Literals
Among the large number of new features in ES6/ES2015 are Template Literals/Strings.
These are backtick "`" enclosed expressions that allow for multiline expressions and string interpolations using placeholders (${varName}
).
White space is significant. Inserting spaces or newline characters will change the resulting string.
If we insert newline characters into myTemplateString
will produce a different result that may not be what you're expecting.
Along with Template Literals, ES6 provided Tagged Template Literals.
Tagged Template Literals allows developers to run a template string through a function with tighter control over how this actual string is made.
To create a Tagged Template String we do the following:
- Create the function that we want to run
- Put the name of the function before the Template String
In a first, naive, implementation, the highlight
function will just return a string, creating a wholly unexpected result.
We need to make the function return something more useful.
We will recreate the highlight function with two parameters
- An array of the string elements of the template
- One or more parameters for the interpolated values we want to use
The next version the highlight
function looks like this:
But it still produces cool
as the output.
For the next iteration, we'll make the following changes.
- Rather than hardcoding the values, we will use the spread syntax to capture all the values that are not strings. This makes the function more flexible when we don't know how many values we'll pass to the function
- We use a forEach loop to iterate through both the strings and values array inserting them where appropriate
If we return str, the string that we've been tacking things onto, we should now see "My name is William and I own a Ferrariundefined."
The strings array is always going to be one larger than the values array. When we hit that last one, it's only going to be a string and there's going to be no value to tack on the end. You could check if values[i]
is undefined and, if it is, then add an empty string.
This will allow us to add as many values as we want or need to without worries of an undefined value sneaking in at the end.
In Easy Creation of HTML with JavaScript’s Template Strings, Wes Bos provides examples of how we can leverage Tagged Template Literals to create HTML content.
Lit HTML rendering uses Tagged String Literals to render HTML and CSS in Lit-HTML-based components.