检查C#中的空值 - Webmatrix

时间:2013-06-20 16:31:15

标签: c# asp.net razor webmatrix

我正在填充输入字段值,有时值存在,有时我不需要检查值是否为空,如果不是则不显示。我目前的代码是使用.IsNullOrEmpty:

<input id="lead-entry" class="form-textbox" type="text" size="5" name="q15_2013Collections[0][]" 
 value="@(queryinputvalue.FirstOrDefault(r => r.field_name.Equals("q15_2013Collections[0][]")).field_data.IsNullOrEmpty 
       ? "" 
       : queryinputvalue.FirstOrDefault(r =>  r.field_name.Equals("q15_2013Collections[0][]")).field_data) " />

这给了我错误:

Exception Details: Microsoft.CSharp.RuntimeBinder.RuntimeBinderException: Cannot perform runtime binding on a null reference

由于

编辑:这是我最终使用的代码:

Helpers.cshtml

@helper checkEmpty(IEnumerable<dynamic> queryinputvalue, string field_id) {    
    var reqValue = queryinputvalue.FirstOrDefault(r => r.field_name.Equals(field_id));
    var return_value = "";
    if(reqValue != null){
        return_value = reqValue.field_data;
    } else {
        return_value = "";
        }
    @return_value
}

在页面上

@{
IEnumerable<dynamic> queryinputvalue = db.Query("SELECT * FROM document_data WHERE doc_id = @0", doc_id);
}

<input type="text" class=" form-textbox" id="input_4" name="q4_arborLoan" size="20" value="@Helpers.checkEmpty(queryinputvalue,"q4_arborLoan")" />

1 个答案:

答案 0 :(得分:4)

你为什么要在View中这样做?您必须在填充ViewModel时在控制器中检查这些条件,如下所示:

public class ViewModel
{
  public string QueryValue {get ; set;}
}

在您的控制器方法中,您只需填充此模型并将其返回到“查看”页面。

public ActionResult MyMethod()
{
    ViewModel model = new ViewModel();
    //Get someValue from anywhere.
    string reqValue = someValue.FirstOrDefault(r => r.field_name.Equals("q15_2013Collections[0][]"));
    string queryValue = string.Empty();
    if(queryValues != null)
    {
       queryValue = string.IsNullOrEmpty(reqValue .field_data)
                  ? ""
                  : reqValue .field_data;
    }
    model.QueryValue = queryValue ;               
    return View(model);
}

因此,您的视图将变为

@model ViewModel

<input id="lead-entry" class="form-textbox" type="text" size="5" name="q15_2013Collections[0][]" value="@Model.QueryValue" />