开发者

Jquery Loop through list and replace

I'm trying to find a way to loop through a list with Jquery, and if a certain class has text of "Not Complete", replace the words "Not Complete" with a animated gif.

Here's the list:

开发者_如何学编程<ul>
<li class="name">Name</li>
<li class="job">This</li>
<li class="status">Not Complete</li>
</ul>

The list is populated via a php script.

I tired this from another example here, but couldn't get it to work:

function change(){
if($('.status').text=='Not Complete')
{$('.status').replaceWith('<img src='loading.gif' />');}
else{}
}

$(function() {
  $(".status").each(change);
});

Any idea's of how I could get this working?


If the .status elements just have short text snippets (not long paragraphs of text), it should be safe to use the contains-selector[docs].

$('li.status:contains(Not Complete)').html("<img src='loading.gif' />");

Notice that I alternated the quotation marks in the HTML. You used only single quotes, which was terminating the string prematurely.

I also added the element-selector[docs] since :contains() is not a standard selector. This will speed things up because now it will only have to look at <li> elements.


Working example: http://jsfiddle.net/PahVB/1/


You forgot to call the text() function:

$('.status').text() == ...

Your code checks whether the function itself is equal to 'Not Complete'.


If the list is populated by PHP, why not just make PHP put it in there in the first place?

But if you're sticking with the jQuery, it should be text()==, not just text==.


Hmm - you need to rewrite this a little as you are currently running a loop, but then within the loop querying the collection again with if($('.status')

Try this:

 $(function() {
      $(".status").each(function(){
           if($(this).text() == 'Not Complete'){
              $(this).replaceWith('<img src='loading.gif' />');
      });
 });


<script>
$(".status").each(function()
{
    if($(this).text() == "Not Complete")
    {
        $(this).html("<img src='loading.gif' />");
    }
});

</script>

Maybe give this a try


The each function typically passes a parameter for index and object of the array you are iterating over. In your function you reselect the array each time. Try something like:

$(".status").each(function(index, value) {  
    if ($(this).text()=="Not Complete")  
    {  
        $(this).replaceWith($("<img />").attr("src","loading.gif"));  
    }  
}

This is based on the jQuery documentation for the each function http://api.jquery.com/each/

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜