4 Things You Must Do When Putting HTML in JSON

Banner ad for SFTP Gateway Version 3.0

Putting HTML in JSON – Four Things You Must Do

There are 4 things you must do when putting HTML in JSON data structures. These items were originally included in a recent post about using XSLT to include HTML in JSON. However, this information is good for anyone to remember when creating JSON data, regardless of whether XSLT is used or not.

The JSON spec does not have many restrictions. JSON data is either a string, a number, a boolean, an object, an array, or null. As long as your data is formatted as one of these types, it should be valid. However, if your data contains HTML, there are certain things that you need to do to keep the browser happy when using your JSON data within Javascript.

  1. Escape quotation marks used around HTML attributes like so <img src=\"someimage.png\" />
  2. Escape the forward slash in HTML end tags. <div>Hello World!<\/div>. This is an ancient artifact of an old HTML spec that didn’t want html parsers to get confused when putting strings in a <SCRIPT> tag. For some reason, today’s browsers still like it.
  3. This one was totally bizarre. You should include a space between the tag name and the slash on self closing tags. I have no idea why this is, but on MOST modern browsers, if you try using javascript to append a <li> tag as a child of an unordered list that is formatted like so: <ul/>, it won’t work. It gets added to the DOM after the ul tag. But, if the code looks like this: <ul /> (notice the space before the /), everything works fine. Very strange indeed.
  4. Be sure to encode any quotation marks that might be included in (bad) HTML content. This is the only thing that would really break the JSON by accidentally terminating the string early. Any " characters should be encoded as &quot; if it is meant to be included as HTML content.

Here is a fictional example of JSON data that shows each of these suggestions. This was based on a real-world example where list items (<li> tags), where added to the <ul> dynamically in Javascript.
{
"ad_box": {
"html": "<div class=\"ad_box\"><img class=\"banner\" src=\"some_ad.png\" alt=\"\" \/>
<h3>&quot;Hot&quot; Items <\/h3> <br \/> <ul id=\"items\" \/><\/div>",
"item_id": 1234,
"click_action":"/logAction?id=1234&amp;type=click&amp;info=blah",
"icon":"http://my.images.com/icons/icon.png"
}
}

Hopefully anyone attempting to serialize HTML as JSON will find these lessons-learned helpful.

Like this post? Please share it! Then follow us on Twitter – @thorntech – and sign up for our email list below for future updates. You can also find us on LinkedIn and Medium. Be sure to check our SFTP Gateway if you need to transfer files to cloud storage locations like Amazon S3, Azure Blob Storage and Google Cloud Storage. 

Get insights on SFTP Gateway, cloud computing and more, in your inbox.

Get smarter about all things tech. Sign up now!

Discover SFTP Gateway

Get real-time access to Amazon S3, Azure Blob Storage and Google Cloud Storage through any SFTP client. Manage users, credentials and folders with ease, using a simple web interface.

Try SFTP Gateway for AWS

Try SFTP Gateway for Azure

Try SFTP Gateway for Google

Learn more about SFTP Gateway

Search our blog

Recent posts

Help with an SFTP server connection

The Thorn Technologies YouTube channel is filled with videos to help you with cloud computing and file transfers. In the newest set of videos, our team walks you through how to set up an SFTP

Read More »
Scroll to Top