Or even easier if you are only dealing with 10 digit phone numbers:
Regex.Replace(phoneNum, @"(\d{3})(\d{3})(\d{4})", "($1) $2-$3");
Read-Only
If you're only interested in displaying the phone number, you could make it an HTML helper like this:
public static MvcHtmlString FormatPhoneNum(this HtmlHelper helper, string phoneNum)
{
//You could strip non-digits here to make it more robust
if (String.IsNullOrEmpty(phoneNum)) return phoneNum;
return new MvcHtmlString(Regex.Replace(phoneNum, @"(\d{3})(\d{3})(\d{4})", "($1) $2-$3")); //US Phone Number
}
And then use like this:
@foreach (var client in Model.Clients)
{
<td>@Html.FormatPhoneNumber(client.TelephoneNumber)</td>
}
Editing
If you also need to edit the phone number and want to display it formatted in the editor textbox, you can create a wrapper property on your view model to transform the phone number:
public class Client
{
public string TelephoneNumber {get; set;}
//Require 10 digits, each surrounded by any non-digit characters (will strip all non-digits)
[RegularExpression(@"(\D*\d\D*){10}", ErrorMessage = "Please enter a 10 digit phone number")]
public string FormattedPhoneNum
{
get
{
MyHelpers.FormatPhoneNumber(TelephoneNumber);
}
set
{
TelephoneNumber = MyHelpers.StripPhoneNumber(value);
}
}
}
public class MyHelpers
{
public static StripPhoneNumber(string phone)
{
if (phone == null)
return phone;
else
return _nonDigits.Replace(phone, String.Empty);
}
public static string FormatPhoneNumber(string phoneNum)
{
phoneNum = StripPhoneNumber(phoneNum);
if (String.IsNullOrEmpty(phoneNum)) return phoneNum;
return Regex.Replace(phoneNum, @"(\d{3})(\d{3})(\d{4})", "($1) $2-$3"); //US Phone Number
}
}
Note the RegularExpressionAttribute on the property. It takes a very lenient stance on user input. It is satisfied as long as the user enters at least 10 digits into the textbox regardless of any other characters typed in. You might need to make this more restrictive for your own purposes.