Blogs > Placeholders in Edge Delivery Services
AEM EDS
Placeholders in Edge Delivery Services
| December 30, 2024Happy to find you here. Welcome to another learning.
What is Placeholder?
Placeholders in AEM Edge Delivery Services (EDS) are dynamically replaceable tokens or variables that are used in configurations, rules, or templates to customize content delivery based on contextual data. They act as placeholders for dynamic values that are resolved at runtime, such as user-specific details, device information, geolocation, or other attributes.
In most websites, there are strings or variables that will be used throughout the site. Especially in sites that need to support multiple languages, it is not a good idea to hard code such values. Instead, placeholders can be used and managed centrally.
Placeholder can be managed as a spreadsheet that is either in the root folder of the project or in the locales root folder in the case of multilingual site
I will be explaining the placeholder concept using the example of multilingual site we will provide region specific content using placeholder
Steps to implement placeholder for region specific content
So let say I have only one site which is in English language but later i expanded it to french as well. So I wanted to display same content in English as well as in french so for that what is will do is I will create a sheet called placeholder in each hierarchy of English and french. As shown below.
Inside this sheet we need to create two columns Key and Text.In English we write as “First Name” but in french this is written as “Prénom” and on the site as well it should display as it is.
Now on the basis of meta data of the page we will pick the value that we wanted to display on the page so for that we have added metadata to the respective pages as shown below.We have added locale and Language metadata to the en and fr pages.
Now inside the en and fr pages we will create a block name Author in that it will have only heading of the block and rest data will come from the JS.
Now there is inbuilt library to read the placeholder file it will read the placeholder file which is present in the root folder but we will customize that logic so that is should read the placeholder files kept in the respective “en” and “fr” hierarchy.Below is the logic change we did based on the prefix we will read the file. Prefix can be “en” or “fr” this is present under aem.js
Now we will write CSS and JS for it inside the respective blocks js and we will create a table displaying first name in English and french languages in respective pages.
data:image/s3,"s3://crabby-images/0e0ba/0e0ba2a0a416b1f3788b65e9bfa2897299766b4e" alt="language-specific-files"
data:image/s3,"s3://crabby-images/cb52c/cb52c2492ded62d5bb3d54d056c097039705986a" alt="placeholder-spreadsheet-content"
data:image/s3,"s3://crabby-images/686b6/686b6b0fdb772d8919f49ad04a7e8f5a66eebc51" alt="metadata-for-locale"
data:image/s3,"s3://crabby-images/ab8dd/ab8ddc02ebf2b54fea7cab085fe06f6aa32c81fd" alt="Author-block"
data:image/s3,"s3://crabby-images/f47ab/f47abdee982673c1c461dcd21af015dcd2d1ed28" alt="aemjs-code"
data:image/s3,"s3://crabby-images/e7352/e735284d702b7ccded9a03e35dbd04fb2f4a2a7f" alt="block-code"
As you can see we have read the metadata property which is locale and on the basis of that we brought the values of placeholder and we are displaying on the page as shown in the blow image
data:image/s3,"s3://crabby-images/f3480/f3480fc1c94519a7d89bc08ab7635ac1dc39e9f7" alt="final-output"
Thanks for reading 😄