Meteor только тригерный шаблон после выбора элемента из списка
-
21-12-2019 - |
Вопрос
У меня есть типичный сценарий, где есть вид списка, а затем представление деталей.Вы добираетесь до представления деталей, выбрав элемент списка.В записи данных есть данные, которые, конечно, будут проинформировать представление макета деталей.То, что я вижу, состоит в том, что функция помощника подпункта вызывается слишком рано (во время рендеринга представления списка), чтобы получить данные для деталей списка.Кроме того, он не вызывается, когда я нажимаю элемент в списке.Что я делаю неправильно?Я использую Meteor 0.8.2 с JQM 1.4.3.
HTML выглядит следующим образом:
<!-- details page -->
<div data-role="page" data-theme="q" id="listdetail">
<div data-role="header" data-position="fixed">
<a data-rel="back" href="#" data-transition="slideleft" class="baack fa fa-arrow-left"></a>
<div id="detailTitle" class="headertitle"></div>
</div>
<!-- /header -->
<div data-role="content" class="ma-req-detail" id="details">
{{> qDetails}}
</div>
</div>
<!-- /details page -->
<template name="qList">
{{#each items}}
{{>qListItems}}
{{/each}}
</template>
<template name="qListItems">
<li>
<div id="msg-container-{{requestId}}" class="processing-msg">
<a href="#" data-rel="back" data-role="button" data-iconpos="notext" class="ui-btn-right msg-dismiss"><i class="fa fa-2x fa-times-circle"></i></a>
<p class="msg-text-{{requestId}}">Action pending...</p>
</div>
<a id="requestId" href="#listdetail" data-name="{{additionalProperties}}" data-transition="slide" class="{{#if isProcessing}}ui-disabled{{/if}}">
<p class="requestor">{{additionalProperties.requestedForUid}}</p>
<p class="description">week of {{additionalProperties.workWeekOf}}</p>
<p class="reqdate">total hours: </p>
</a>
</li>
</template>
<template name="qDetails" >
<div role="main" class="q-details">
<div data-role="navbar" class="week-nav">
<ul>
{{#each days}}
{{>navElements}}
{{/each}}
</ul>
</div>
</div>
<div class="ma-buttons ui-fieldcontain ui-footer-fixed">
<div data-role="controlgroup" data-type="horizontal" class="" data-position-fixed="true" data-position="bottom">
<a data-mini="true" href="#" id="approve-request"
class="ui-btn ui-btn-c ui-corner-r ui-icon-check ui-btn-icon-left ma-btn approve">Approve</a>
</div>
</div>
</template>
<template name="navElements">
<li><a id="{{day}}Nav" href="#{{day}}">{{day}}<br><span class="digital-date">{{date}}</span></a></li>
</template>
.
Биты JS:
Template.qDetails.rendered = function() {
$('#details').trigger('create');
};
Template.qDetails.helpers({
days: function() {
//TODO need a way to delay this function to call when details template is shown
var dt = Session.get("record").additionalProperties.workWeekOf;
var days = [];
var weekday = new Array(7);
weekday[0] = "SAT";
weekday[1] = "SUN";
weekday[2] = "MON";
weekday[3] = "TUE";
weekday[4] = "WED";
weekday[5] = "THU";
weekday[6] = "FRI";
var dtVal = dt.getDate();
for (var i = 0; i < 7; i++) {
var dayObj = {};
dayObj.date = dtVal + i;
dayObj.day = weekday[i];
days.push(dayObj);
}
return days;
}
});
Template.qDetails.record = function () {
return Session.get("record");
};
.
В коде выше функции помощника «Дней» называется, когда отображается страница списка, которая приводит к ошибке, потому что она пытается вытащить дату «WorkWeekof» из записи, которая еще не была выбрана.Как я могу добраться до этого звонка, когда запись была выбрана?
Решение
Это слегка сбивает с толку, поскольку в приведенном выше нет ничего, что показывает, как шаблон вашего генеракодицетагкода находятся в первую очередь.Однако, если это делает, вы можете просто использовать:
var dt = Session.get("record") ? Session.get("record").additionalProperties.workWeekOf : [default date]
.
qDetails
может быть что-нибудь разумное (например, [default date]
), но вам нужно вернуть что-то, чтобы избежать брошенного ошибки.Это довольно распространенная, но очень легко решающая проблема в METEOR - вам просто нужно подходящее значение по умолчанию, когда ваша переменная или коллекция сеанса еще не готова.