1

I have some code that for some reason I can't split up:

<li class="task-list-item done">
<div class="task-icon">
    <a href="javascript:;">
        <i class="fa fa-database"></i>
    </a>
</div>
<div class="task-status">
    <a class="done" href="javascript:;">
        <i class="fa fa-check"></i>
    </a>
    <a class="pending" href="javascript:;">
        <i class="fa fa-close"></i>
    </a>
</div>
<div class="task-content">
    <h4 class="uppercase bold">
        <a href="javascript:;">Directive</a>
    </h4>
    <p>blagh {{unit.elements.journal.definition.directive}}</p>
</div>
</li>

renders fine

but

<li ng-repeat="definition in unit.elements.journal.definition" class="task-list-item done">
    <div class="task-icon">
        <a href="javascript:;">
        <i class="fa fa-database"></i>
        </a>
    </div>
    <div class="task-status">
        <a class="done" href="javascript:;">
        <i class="fa fa-check"></i>
        </a>
        <a class="pending" href="javascript:;">
        <i class="fa fa-close"></i>
        </a>
    </div>
    <div class="task-content">
        <h4 class="uppercase bold">
        <a href="javascript:;">Directive</a>
        </h4>
        <p>blagh {{definition.directive}}</p>
    </div>
</li>

doesn't work.

Why can't I nest ng-repeat properly? I've done something similar before and I didn't have any issues, and right now I don't even know how to debug this properly. This makes no sense to me.

2
  • i belive unit.elements.journal.definition.directive is object. try (key, value) in unit.elements.journal.definition Commented Oct 5, 2016 at 16:46
  • when you aren't absolutely sure it's easy to inspect what you are working with in view doing: <pre>{{unit.elements.journal.definition | json}}</pre> Commented Oct 5, 2016 at 17:05

1 Answer 1

2

Are you sure unit.elements.journal.definition is an array? Based on your snippet is seems like an object because you're calling a property from it unit.elements.journal.definition.

Try this and see if it renders properly, if it does that's certainly a problem in your array.

<li ng-repeat="definition in [{directive: 'test'}]" class="task-list-item done">
  <div class="task-icon">
    <a href="javascript:;">
    <i class="fa fa-database"></i>
    </a>
  </div>
  <div class="task-status">
    <a class="done" href="javascript:;">
    <i class="fa fa-check"></i>
    </a>
    <a class="pending" href="javascript:;">
    <i class="fa fa-close"></i>
    </a>
  </div>
  <div class="task-content">
    <h4 class="uppercase bold">
      <a href="javascript:;">Directive</a>
    </h4>
    <p>blagh {{definition.directive}}</p>
  </div>
</li>
Sign up to request clarification or add additional context in comments.

1 Comment

it isn't an array... I guess that's causing the issue. Stupid me. Thank you!

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.