Prijímanie dát odkazuje na proces pridávania správania skriptu JavaScript späť do kompilovaného obsahu HTML na stránke, keď sa HTML vykresľuje v prehľadávači.
Ak máte na stránke napríklad dva komponenty, ktoré chcete vykresliť ako hlavný/detailný, potom po kliknutí na položku v hlavnom komponente bude potrebné aktualizovať aj detailný komponent. O toto všetko sa stará JavaScript, ktorý sa spúšťa na stránke. Aby to fungovalo, po vykreslení týchto dvoch komponentov na stránke bude pre ne potrebné prijať dáta do obsahu HTML, a to pridaním obslužného programu udalosti on click k prvkom v hlavnom komponente a pridaním prijímača do kontajnera detailných komponentov kvôli opätovnému vykresleniu, keď nastane udalosť on click na základe odovzdania payloadu do udalosti.
Kompilátory komponentov vložia HTML na stránku. Ak komponent potrebuje spustiť v čase behu ďalší JavaScript na pridanie vecí, ako sú obslužné programy udalostí, potom máte dve možnosti – vnorený JavaScript alebo funkciu prijímania dát. Výber riešenia závisí od vašich požiadaviek.
Značku <script> môžete vložiť priamo do vráteného kompilovaného markupu. Skript sa bude spúšťať zároveň so stránkou.
Príklad:
<script src="/_sitesclouddelivery/renderer/libs/scs-core/jssor-
slider/js/jssor.slider.min.js" type="text/javascript"></script>
<div id="slider_container_c46b122d-978a-429d-aa25-9b5698428f6f"
style="position: relative; top: 0px; left: 0px; height: 400px; width: 600px;
background-color: rgb(68, 68, 68); visibility: visible;" data-jssor-
slider="1">
. . .
</div>
<script>
(function () {
// get the required options
var options =
{"$FillMode":2,"$AutoPlay":false,"$AutoPlayInterval":3000,"$SlideDuration":50
0,"$ArrowKeyNavigation":true,"$HWA":false,"$BulletNavigatorOptions":{"$Chance
ToShow":1,"$AutoCenter":1,"$SpacingX":5},"$ArrowNavigatorOptions":{"$ChanceTo
Show":1,"$AutoCenter":2,"$Steps":1},"$ThumbnailNavigatorOptions":{"$ChanceToS
how":0,"$DisplayPieces":7,"$SpacingX":8,"$ParkingPosition":240}};
// select the JSSOR value options
options.$BulletNavigatorOptions.$Class = $JssorBulletNavigator$;
options.$ArrowNavigatorOptions.$Class = $JssorArrowNavigator$;
options.$ThumbnailNavigatorOptions.$Class =
$JssorThumbnailNavigator$;
// create the slider
var slider = new $JssorSlider$("slider_container_c46b122d-978a-
429d-aa25-9b5698428f6f", options);
// resize, maintaining aspect ratio
var container = slider.$Elmt.parentElement;
if (container) {
slider.$ScaleWidth(container.getBoundingClientRect().width);
}
})();
</script>
Namiesto vnorenia kódu JavaScript môžete do súboru render.js zahrnúť funkciu prijímania dát a poznamenať, že komponent vyžaduje prijímanie dát v čase behu pri vrátení kompilovaného markupu. Funkcia prijímania dát zabraňuje opakovaniu značiek <script> a na spravovanie udalostí umožňuje využívať existujúci kód JavaScript.
Aj keď sa načíta súbor render.js, funkcia render() sa počas prijímania dát nezavolá. Zavolá sa len funkcia hydrate().
Poznámka:
Ak kompilovaný komponent neupozorní, že potrebuje prijať dáta, súborrender.js komponentu sa nikdy nenačíta.Vlastný kompilátor rozloženia obsahu by sa napríklad vrátil s voľbou - { hydrate: true }.
return Promise.resolve({
content: compiledContent,
hydrate: true // note that we want to hydrate this component using the
render.js hydrate() function. This is required for when the user clicks on
the author
});
Navyše, ak je to potrebné, vlastný kompilátor môže pridať vlastnosti prijímania dát, ktoré bude vyhľadávať v čase behu. Príklad:
Compiler:
// calculate the hydrate data
content.hydrateData = JSON.stringify({
contentId: content.id,
authorName: content.fields['starter-blog-author_name']
});
. . .
Template:
<div class="author-container" data-hydrate="{{hydrateData}}">
Ak komponent upozorní, že potrebuje prijať dáta, v čase behu sa načíta súbor render.js komponentu a zavolá sa funkcia hydrate(), pričom sa odovzdá kontajner <div>, ktorý obsahuje kompilovaný markup.
Napríklad súbor render.js – pozrite si funkciu hydrate():
function selectAuthor(parentObj, contentId, authorName) {
var $parentObj = $(parentObj);
$parentObj.find(".author-name").click($.proxy(function () {
$(".author-name").removeClass('author-selected');
$(event.target).addClass('author-selected');
}, self));
if (window.location.href.indexOf("default=" + contentId) >= 0) {
$(".author-name").each(function () {
if (this.innerText === authorName) {
$(this).addClass('author-selected');
}
});
}
}
. . .
hydrate: function (parentObj) {
var $parentObj = $(parentObj),
hydrateData = $parentObj.find('.author-container').attr('data-
hydrate');
if (hydrateData) {
var data = JSON.parse(hydrateData);
selectAuthor(parentObj, data.contentId, data.authorName);
}
},
render: function (parentObj) {
. . .
try {
// Mustache
template = Mustache.render(templateHtml, content);
if (template) {
$(parentObj).append(template);
}
selectAuthor(parentObj, this.contentItemData.id,
content.fields['starter-blog-author_name']);
} catch (e) {
console.error(e.stack);
}
}