views:

437

answers:

2

I have the following string:

This *is* a *test*!

I want to bold the words surrounded by the * characters (so "is" and "test" in the example).

I have the following JavaScript code:

var data = "This *is* a *test*!";
return data.replace(/\*(.*)\*/g, <b>$1</b>);

When the string is returned, I get the following:

This <b>is* a *test</b>!

How can I change the pattern or basic code in order to do the replacement the way I want it?

+1  A: 

SO messed with my HTML...

result = "This *is* a *test*!".replace(/\*(.*?)\*/ig, "<b>$1</b>");

Bryan Migliorisi
+1  A: 

You need to make the pattern non-greedy by adding the ?-operator after the *:

var data = "This *is* a *test*!";
return data.replace(/\*(.*?)\*/g, "<b>$1</b>");

Here is a reference for JavaScript RegExp from Mozilla Developer Center.

PatrikAkerstrand