2010-05-06 111 views
3

我需要幫助的一兩件事之一:jQuery的,選擇,包含文本

這是我的jQuery的想法:

 var text = "Some Text1, Some Text2, Some Text3"; 


     $("h3:contains('"+even one of this string+"')").each(function() { 
       $(this).append("<span>Some Text</span>"); 
     }); 

這是我的HTML

  <h3 class="test1">Some Text2</h3> 

      <h3 class="test1">Some Text1</h3> 

      <h3 class="test3">Another Text</h3> 

我想在輸出:

   <h3 class="test1"> 
       Some Text2 
       <span>Some Text</span> 
      </h3> 

      <h3 class="test1"> 
       Some Text1 
       <span>Some Text</span> 
      </h3> 

      <h3 class="test3">Another Text</h3> 

謝謝!

+0

文本的數量可以不同,串 – AlexC 2010-05-06 01:33:44

回答

4

快速的jQuery

var text = "Some Text1, Some Text2, Some Text3"; 

$(document).ready(function(){ 
    $(text.split(", ")).each(function(i,v){ 
    $('h3:contains("'+ v +'")').append('<span>Some text</span>'); 
    }) 
}) 

快速demo

1

你想:

$("h3:contains('Some Text1'), h3:contains('Some Text2'), h3:contains('Some Text3')").each(function() { 
      $(this).append("<span>Some Text</span>"); 
    }); 

編輯

針對OP評論,請注意,您可以執行以下操作:

var text = "Some Text1, Some Text2, Some Text3"; 

text.replace(/\s?([^,]+?)(,)|\s([^,]+?)$/g, "h3:contains('$1$3')$2"); 

要生成元素列表。

然後你做:

var text = "Some Text1, Some Text2, Some Text3"; 

text.replace(/\s?([^,]+?)(,)|\s([^,]+?)$/g, "h3:contains('$1$3')$2"); 

$(text).each(function() { 
      $(this).append("<span>Some Text</span>"); 
    }); 

這將替換所有的逗號由H3包圍這個詞本身分隔的術語:包含(「和」)。這些將以與原始字符串相同的方式用逗號分隔。

+0

的也可以是百分之文字 – AlexC 2010-05-06 01:32:55

0

簡單的解決辦法,如果你事先知道你的字符串是使用多個選擇,像這樣:

$("h3:contains('Some Text1'), h3:contains('Some Text2'), h3:contains('Some Text3')").each(function() { 
    $(this).append("<span>Some Text</span>"); 
}); 
3
var text = "Some Text1, Some Text2, Some Text3"; 

var aText = text.split(","); //splits into array on comma delimiter 


for (var i = 0; i < aText.length; i++) { 
    $("h3:contains('" + aText[i] + "')").each(function() { 
     $(this).append("<span>Some Text</span>"); 
    }); 

} 

這應該爲你工作(但不清楚的,如果你能打破輸入/輸出的選擇串那樣的。讓我知道它的好。

3

只需遍歷標題並在$(this).text()上進行正則表達式匹配即可。你甚至可以到自定義選擇這個,如果你真的想:

$.extend($.expr[':'], { 
    matches: function(node, index, args, stack) { 
    var re = new RegExp(args[3]); 
    return !!$(node).text().match(re); 
    } 
}); 

$(function() { 
    $('h3:matches("Some Text[123]")').each(function() { 
    $(this).append("<span>Some Text</span>"); 
    }); 
});