我有一个KendoUI网格,允许用户使用内联模式更新值。问题是我有两个不允许空值的 double 属性,但是NumericTextBox让我设置一个空值,然后接受它,如下图所示:
如果按“Aceptar”(“Accept”)按钮,输入将保持为空,但它会在数据库中保存“0”,并且只有在刷新页面时才能看到它。 这是网格的代码:
@(Html.Kendo().Grid<ReferenceThresholdVM>()
.Name("grdReference")
.Columns(columns =>
{
columns.Bound(t => t.txbTransponderName).Title("Transponder").Width(120);
columns.Bound(t => t.txbDataSourceName).Title("Variable").Width(200);
columns.ForeignKey(t => t.ddlReferenceTypeId, ReferenceTypeVM.GetComboList(), "Id", "Description").Title("Modo").Width(110);
columns.Bound(t => t.ntbThreshold).Title("Umbral").Width(100);
columns.Bound(t => t.ntbCurrentValue).Title("Valor de referencia").Format("{0:n2}").Width(170);
columns.Bound(t => t.ntbHysteresis).Title("Histeresis").Format("{0:n2}").Width(100);
columns.Bound(t => t.ntbThresholdTrigger).Title("Umbral de disparo").Format("{0:n2}").Width(150);
columns.Command(command =>
{
command.Edit().CancelText("Cancelar").UpdateText("Confirmar");
command.Destroy();
}).Width(220).HtmlAttributes(new { style = "text-align: center;" });
})
.Editable(editable => editable.Mode(GridEditMode.InLine))
.Pageable()
.Navigatable()
.Sortable()
.Events(e => e.Save("onSave"))
.DataSource(dataSource => dataSource
.Ajax()
.PageSize(12)
.ServerOperation(false)
.Events(events => events.Error("error_handler"))
.Model(model =>
{
model.Id(t => t.Id);
model.Field(t => t.Id);
model.Field(t => t.txbTransponderName).Editable(false);
model.Field(t => t.txbDataSourceName).Editable(false);
model.Field(t => t.ddlReferenceTypeId);
model.Field(t => t.ntbThreshold);
model.Field(t => t.ntbHysteresis);
model.Field(t => t.ntbCurrentValue).Editable(false);
model.Field(t => t.ntbThresholdTrigger).Editable(false);
})
.Read(read => read
.Action("Read_Reference", "Reference")
.Data("getFilterReference")
)
.Update("Reference_Update", "Reference")
.Destroy("Reference_Destroy", "Reference")
)
.Events(events => events.DataBound("onGrdReferenceDataBound"))
.AutoBind(false)
)
通过使用定义输入行为的UIHint,以这种方式定义每个属性:
[Display(Name = "Umbral")]
[UIHint("PositiveNumber")]
public double ntbThreshold
{
get;
set;
}
[Display(Name = "Histeresis")]
[UIHint("PositiveNumber")]
public double ntbHysteresis
{
get;
set;
}
最后这是UIHint“PositiveNumber”的代码:
@model int?
@(Html.Kendo().NumericTextBoxFor(m => m)
.HtmlAttributes(new { @class = "k-numerictextbox" })
.Min(0)
.Max(int.MaxValue)
.Value(0)
)
有没有办法禁用让NumericTextBox为空的可能性?
答案 0 :(得分:1)
数字文本框上.Value的工具提示说,“设置文本框的初始值”。所以这就像为什么它在数据库中保存0。
根据我的评论,您可能实际上必须做这样的事情。
var numerictextbox = $("#numerictextbox").data("kendoNumericTextBox");
numerictextbox.value(0);
答案 1 :(得分:0)
感谢大家!我通过在属性上使用“必需”装饰器来解决它。
[Required] /*this is the important thing!*/
[Display(Name = "Umbral")]
[UIHint("PositiveNumber")]
public double? ntbThreshold
{
get;
set;
}
[Required]
[Display(Name = "Histeresis")]
[UIHint("PositiveNumber")]
public double? ntbHysteresis
{
get;
set;
}
现在,当您尝试设置空值时,它会显示验证错误。因此,如果要在NumericTextBox上设置0,则必须编写它。