【发布时间】:2019-04-14 07:47:00
【问题描述】:
我正在创建一个非常小的应用程序来演示可靠的原则以及构建器模式的简要实现,是否有人对如何改进或它如何违反可靠原则有任何反馈?该应用程序是一个仅转换单位的小型应用程序,例如码到米,英寸到厘米。
界面
public interface IConverter
{
double ConversionRate { get; set; }
string[] ConvertedUnits { get; set; }
string DisplayText { get; set; }
string[] Convert(string input);
}
类实现接口
public class Converter : IConverter
{
public double ConversionRate { get; set; }
public string[] ConvertedUnits { get; set; }
public string DisplayText { get; set; }
public Converter(double conversionRate, string[] convertedUnits, string displayText)
{
ConversionRate = conversionRate;
ConvertedUnits = convertedUnits;
DisplayText = displayText;
}
public string[] Convert(string input)
{
if (!input.Contains('\n'))
{
double d = double.Parse(input, CultureInfo.InvariantCulture) * ConversionRate;
string[] array = new string[1];
array[0] = d.ToString();
return array;
}
else
{
double[] doubles = new double[input.Split('\n').Count()];
for (int i = 0; i < input.Split('\n').Count(); i++)
{
double value = double.Parse(input.Split('\n')[i]);
doubles[i] = value;
string.Format("{0}", value * ConversionRate);
}
string[] strings = new string[doubles.Length];
for (int i = 0; i < input.Split('\n').Length; i++)
{
strings[i] = string.Format("{0}", doubles[i] * ConversionRate);
}
return strings;
}
}
}
生成器(抽象类)
public abstract class ConverterBuilder
{
protected double _conversionRate;
protected string[] _convertedUnits;
protected string _displayText;
public ConverterBuilder AddConversionRate(double conversionRate)
{
_conversionRate = conversionRate;
return this;
}
public ConverterBuilder AddConversionRate(string[] convertedUnits)
{
_convertedUnits = convertedUnits;
return this;
}
public ConverterBuilder AddDisplayText(string displayText)
{
_displayText = displayText;
return this;
}
public Converter Build()
{
return new Converter(_conversionRate, _convertedUnits, _displayText);
}
}
构建器实现抽象构建器类
public class UnitConverterBuilder : ConverterBuilder
{
public UnitConverterBuilder()
{
}
}
控制器
public IActionResult Convert(string text, double conversionRate)
{
Converter converter = new UnitConverterBuilder()
.AddConversionRate(conversionRate)
.Build();
string output = "";
for (int i = 0; i < converter.Convert(text).Count(); i++)
{
output += converter.Convert(text)[i] + Environment.NewLine;
}
return Content(output);
}
查看
输入要转换的值
<form asp-controller="Home" asp-action="Convert" method="post">
<textarea id="text" name="text" rows="10" cols="40"></textarea>
<select name="conversionRate">
<option value="">Please Select</option>
<option value="0.9144">Yards to Meters</option>
<option value="2.54">Inches To Centimeters</option>
</select>
<button>Convert</button>
</form>
该应用程序是使用 .net 核心构建的,非常感谢任何反馈:)
【问题讨论】:
-
嗯,在这里我将只有一个静态 UnitConverter 类,其中包含支持的单位(非字符串)和内置转换率的枚举。此外,您的 IConverter 界面的 DisplayText 函数似乎违反了 SOLID。
-
谢谢,在显示文本违反 SOLID 时,您能详细说明一下吗?
-
DisplayText 与转换器的转换工作有什么关系?它违反了单一职责原则——现在你让它对 UI 负责。
-
嗯是的非常好,所以将显示文本移动到类并从界面中删除
-
这个问题属于codereview.stackexchange.com。
标签: .net design-patterns interface .net-core solid-principles