I'm somewhat new to angular, and i'm having problems with my json and ng-repeats. I have a list of "modules" and then lists of "weeks" within them:
{ "modules": { "module1": { "title":"name of module1", "description":"description of module1", "weeks":{"week1":{"title":"Week 01"} }, "module2": { "title":"name of module2", "description":"description of module2", "weeks":{"week2":{"title":"Week 02"},"week3":{"title":"Week 03"} } } }
my final output is a table, and I can get the modules to repeat, but I'm having a hard time understanding what I'm doing wrong by getting the weeks to loop. Here is my template:
<table class="table table-bordered" ng-repeat="module in ocw.modules"> <tr> <td> <h3 class="moduletitle">{{ module.title }}</h3> <h4>Description</h4> <p>{{ module.description }}</p> </td> </tr> <tr ng-repeat="week in ocw.modules.weeks"> <td> {{ week.title }} </td> </tr> </table>
So that will output 2 tables, with the proper titles and descriptions, but I can't seem to get the weeks to display correctly. Note that some "modules" have more that one "week". I'm not really sure if the error is in my template or json.
Thanks for any help. S
I would change your data structure so your modules and weeks are an array of objects.
Demo: http://plnkr.co/edit/e41n9vAMMLf0WWIUQ8HO?p=preview
json data:
{ "modules": [ { "title":"name of module1", "description":"description of module1", "weeks":[{"id":1, "title":"Week 01"}] }, { "title":"name of module2", "description":"description of module2", "weeks":[{"id":2, "title":"Week 02"},{"id":3,"title":"Week 03"}] } ] }
And then your markup would be:
<table class="table table-bordered" ng-repeat="module in ocw.modules"> <tr> <td> <h3 class="moduletitle">{{ module.title }}</h3> <h4>Description</h4> <p>{{ module.description }}</p> </td> </tr> <tr ng-repeat="week in module.weeks"> <td> {{ week.title }} </td> </tr> </table>
As you are iterating over each module which in this case is module
to get the weeks it is just module.weeks
much the same as module.title
. In your example you are inside the iteration and trying to reference ocw.modules.weeks
which doesn't match your json structure.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With