Я согласен с ответом Эртана.Я столкнулся со сценарием, в котором это вызывает неудобства.
У нас есть приложение, которое собирает строковые данные от пользователя через текстовое поле Silverlight и сохраняет эти данные в базе данных SQL Server, что является очень распространенным явлением.Проблема возникает, когда другие компоненты приложения используют хранимые строковые данные, ожидая, что разрывы строк будут представлены "\r\n"
.Одним из примеров такого компонента является решение для отчетности Telerik: См. Проблема с разрывом строки в многострочных текстовых полях .
. Я преодолел эту проблему с помощью этого преобразователя значений:
public class LineBreakCorrectionConverter : IValueConverter
{
private const string CR = "\r";
private const string CRLF = "\r\n";
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
string text = value as string;
if (text == null)
return null;
return text.Replace(CRLF, CR);
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
string text = value as string;
if (text == null)
return null;
return text.Replace(CR, CRLF);
}
}