2017-01-03 7 views
1

Я прочитал много сообщений об этом, включая good tutorial, но я все еще не могу найти, что не так с моим кодом. Я намерен настроить веб-страницу, которую я разрабатываю, чтобы работать с Iron Router.Как визуализировать шаблоны в шаблонах с IronRouter и Meteor

В основном это отображает ряд изображений с титрами и, когда пользователь его выбирает, сообщение отображается в новом шаблоне и формате (поэтому мне нужен Iron Router).

У меня возникли проблемы с настройкой: шаблон ApplicationLayout должен отображать шаблон повышения для каждого пользователя, чтобы отображались все его/ее изображения. Однако, когда он отображается, я получаю html для body.html, но не тот, что в boost.html.

Сценарии Java Script и обработчики событий работают нормально; Я уже проверял это. Вот почему я включаю только код для body.html, boost.html и routes.js. Обратите внимание, что код соответствует трем различным файлам: оба файла html находятся в одной и той же папке (ui), а файл js находится в папке lib, все внутри каталога моего проекта.

Заранее благодарен!

body.html

<template name="ApplicationLayout"> 
    <body> 
    {{> sAlert}} 
     <div id="background"> 
     <img src="http://s1.picswalls.com/wallpapers/2015/11/21/beautiful-motivation-wallpaper_10342177_288.jpg" class="stretch" alt="" /> 
    </div> 
     <div class="container"> 
      <header> 
       {{#if currentUser}} 
       <h1>Your Boosts! ({{incompleteCount}})</h1> 
       {{else}} 
       <h1>Community Boosts!</h1> 
       {{/if}} 
       {{> undoRedoButtons}} 

       {{> loginButtons}} 

       {{#if currentUser}} 
       <form class="new-boosts"> 
        <input type="text" name="text" placeholder="Type to add a short description"/> 
        <input type="text" name="image" accept = "image/*" placeholder="Type to add a picture url"/> 
        <input type="number" name="importance" min = "0" placeholder="Type to choose an importance position"/> 
        <textarea class = "text-area" name="message" rows = "10" cols = "5" placeholder="Type a message for yourself"></textarea> 
        <input type="submit" value="Submit" class="new-boosts first"> 
       </form> 
       {{/if}} 
      </header> 
      <ul> 
       {{#each boosts}} 
        {{> yield}} 
       {{/each}} 
      </ul> 
     </div> 
    </body> 
    </template> 

boost.html

<template name="boost"> 

     <article class="image-with-header"> 
      <img class="image" src="{{image}}" /> 
     </article> 

     <li class="{{#if private}}private{{/if}}"> 
      <button class="delete">&times;</button> 

      {{#if isOwner}} 
       <button class="toggle-private"> 
       {{#if private}} 
       Private 
       {{else}} 
        Public 
       {{/if}} 
       </button> 
      {{/if}} 

      <span class="text"><strong>{{username}}</strong> - <input type="text" value="{{text}}" name="caption"> - <input type="number" value="{{importance}}" name="importance"> </span> 
     </li> 
    </template> 

routes.js

Router.configure({ 
    layoutTemplate: 'ApplicationLayout' 
}); 

Router.route('/', function() { 
    this.layout('ApplicationLayout'); 
    this.render('boost'); 
}); 

ответ

1

Я считаю, что проблема в том, что вы используя {{> yield}} внутри петли each. Попробуйте это:

* .html

<template name="ApplicationLayout"> 
    <body> 
     {{!-- ... --}} 
      <ul> 
      {{> yield}} 
      </ul> 
     {{!-- ... --}} 
    </body> 
</template> 

<template name="boosts"> 
    {{#each boosts}} 
     {{> boost}} 
    {{/each}} 
</template> 

<template name="boost"> 
    {{!-- ... --}} 
</template> 

* .js

// in tempalte file 
Template.boosts.helpers({ 
    boosts() { 
    // return boosts here 
    } 
}); 

// in router file 

Router.configure({ 
    layoutTemplate: 'ApplicationLayout' 
}); 

Router.route('/', function() { 
    this.render('boosts'); 
}); 
+0

что ответили на мой вопрос, и теперь программа работает. Тем не менее, мне было бы интересно понять, почему доходность не работает в каждом цикле. @Khang вы бы случайно знаете, почему Iron Router работает так? Или это просто произвольно? Благодаря! – Lesscomfortable