Нокаут.JS containerless "foreach" не работает
этот код выдает ошибку (в Chrome): "не удается найти закрывающий тег комментария для соответствия: ko foreach: MyPlans":
<table>
<!-- ko foreach: MyPlans -->
<tr>
<td>Test</td>
</tr>
<!-- /ko -->
</table>
Если я использую список вместо этого, все работает:
<ul>
<!-- ko foreach: MyPlans -->
<li>
Test
</li>
<!-- /ko -->
</ul>
Я хотел бы использовать бесконтейнерный foreach с таблицей. Я что-то делаю не так? Это баг?
1 ответ:
это связано с тем, что браузеры вставить
tbodyтеги автоматически, что создает несоответствие в комментариях. Вывод рендеринга будет выглядеть так:<table> <!-- ko foreach: MyPlans --> <tbody> <tr> <td>Test</td> </tr> <!-- /ko --> </tbody> </table>Стив действительно приложил некоторые усилия, пытаясь исправить несоответствующие теги в KO, но самое простое, что вам нужно сделать, это либо добавить
tbodyсамостоятельно или добавитьtbodyи положите на него свою привязку.<table> <tbody data-bind="foreach: MyPlans"> <tr> <td>Test</td> </tr> </tbody> </table>это законно для таблицы, чтобы иметь несколько
tbodyтеги, если это необходимо.