Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
    <head>
      <meta charset="utf-8">
      <title>JS Bin</title>
    </head>
    
    <body
        ng:app="app"
        ng:init="messages = [
            'message 1',
            'message 2',
            'message 3',
            'message 4',
            'message 5'
        ]"
    >
        <stats></stats>
        
        <h3>Without ng:repeat</h3>
        <p>Use the toggle  below on and off multiple times and pay attention to the number of active scopes and watches being used.</p>
        <toggle>
            <li>{{ messages[0] }}</li>
            <li>{{ messages[1] }}</li>
            <li>{{ messages[2] }}</li>
            <li>{{ messages[3] }}</li>
            <li>{{ messages[4] }}</li>
        </toggle>
        <h3>With ng:repeat</h3>
        <p>Now, do the same with the following toggle. This one uses more scopes and watches as it uses ng:repeat.</p>
        <p>Next, uncomment the jquery script tag in the html and try that again... There is a memory leak as it looks like the scopes and watches are not being destroyed, not sure why it happens only with jquery being loaded though...</p>
        <toggle>
            <li ng:repeat="message in messages">{{ message }}</li>
        </toggle>
        
        
        <h1>Bug summary</h1>
        <p>So the bug seems to be only present in the case where an ng:repeat list of elements is being transcluded inside something else, <em>AND</em> jquery is used instead of jqlite.</p>
<!--        <script src="https://code.jquery.com/jquery-2.1.1.min.js"></script> -->
<!--        <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.2 -->4/angular.min.js"></script>
  <script src="https://code.angularjs.org/snapshot/angular.js"></script>
    </body>
    
</html>
Output 300px

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
petebacondarwinpro
0viewers