How To Use Google Tag Manager With Multiple Schema Product Reviews Using JSON-LD And Variables
Solution 1:
You can use custom JavaScript variables to store arrays of values and then set elements of these arrays as values in JSON-LD.
For example, to get the text of H1 tag you can create custom JavaScript variable with this function:
function () {return document.querySelector('h1').innerText;}
Let's say you will name this variable h1. Then you can use this variable as {{h1}} in JSON-LD.
JSON-LD code can be stored in custom HTML tag and filled with variables mentioned above.
If you have more then one H1 on the page you can use this variable:
function () {return document.querySelectorAll('h1');}
It will return an array of elements and you can loop through this array to get innerText or just look at each element like:
{{h1}}[0].innerText
Let me show my idea on this blog post example - https://netpeak.net/blog/modify-your-ppc-strategy-to-suit-voice-search/. You can get all H2 headers (or reviews or anything) from the page like this:
var allh2 = document.querySelectorAll('h2');
In terms of GTM it could be custom JavaScript variable or you can just build one custom HTML tag with JSON-LD. Next you create empty array to store inner text of these headers and push all values as object in JSON-LD notation:
var reviews = [];
for(i = 0; i < allh2.length; i ++){
reviews.push({'review':allh2[i].innerText});
}
Now you have reviews variable that can be used as a value in JSON-LD markup for "reviews" key.
Post a Comment for "How To Use Google Tag Manager With Multiple Schema Product Reviews Using JSON-LD And Variables"