Achieving Angular Ng-repeat Like Feature In Javascript
Im currently working on a code to achieve something like ng-repeat in angular. Basically a for-loop in html. the code takes every element with the class 'loop' and processes it wit
Solution 1:
The replacement fails because the HTML is changed, and the next .loop
reference that jQuery had collected for your for
loop, no longer represents what it was before.
Instead, make your for
loop go in reversed direction:
$($(".loop").get().reverse()).each(function(i){
// etc...
Snippet:
$($(".loop").get().reverse()).each(function(i){
var loop_info=$(this).attr("info");
var fin=loop_info.match(/(.*) in (\d+) to (\d+)/);
var variable=fin[1],
initial=fin[2],
final=fin[3];
var htm=$(this).html(),printed="";
for(j=initial;j<=final;j++){
var temp=htm;
var r=newRegExp("-("+variable+")-","g")
temp=temp.replace(r,j);
printed+=temp;
}
$(this).html(printed);
});
<scriptsrc="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script><divclass="loop"info="i in 1 to 10"><divclass="loop"info="j in 1 to 10">
-i-:-j-
</div></div>
Post a Comment for "Achieving Angular Ng-repeat Like Feature In Javascript"