1

我创建了一个简单的 MVC 应用程序,它从表单中获取信息并将其传递给控制器

看法:

@model MvcApplication1.Models.BetChargeModel


@using (Html.BeginForm())
{
<div>
    @Html.TextBoxFor(m=>m.numerators[0])   /   @Html.TextBoxFor(m=>m.denominators[0])
</div>

<div>
    @Html.TextBoxFor(m => m.numerators[1])   /   @Html.TextBoxFor(m => m.denominators[1])
</div>

<div>
    <input type="submit" value="Calculate" />
</div>
}

控制器:

 public ActionResult Index()
    {
        BetChargeModel model = new BetChargeModel();
        model.numerators = new List<double>();
        model.denominators = new List<double>();
        model.denominators.Add(1);
        model.denominators.Add(1);
        model.numerators.Add(0);
        model.numerators.Add(0);

        return View(model);
    }

[HttpPost]
    public ActionResult Index(BetChargeModel model)
    {
        double odds1 = model.numerators[0] / model.denominators[0];
        double odds = model.numerators[1] / model.denominators[1];

//other code
}

模型:

 public class BetChargeModel
{
    public List<double> numerators { get; set; }

    public List<double> denominators { get; set; }

    public double result { get; set; }

}

当我运行它并尝试从视图中发回信息时,模型返回为空(充满空字段和零)。为什么我的文本框中的数据没有绑定到模型?

(编辑:我已经更改了模型属性和对分子、分母和结果的引用,但为了简洁起见,这里没有更新这些)

4

1 回答 1

4

根据名称numeratorsdenominators您似乎已将列表实现为模型上的字段。

您应该使用属性来代替模型绑定以正常工作(我假设@Raphael 已经完成了)。

工作模型如下所示:

public class BetChargeModel
{
    public List<double> numerators { get; set; }
    public List<double> denominators { get; set; }
}

...并遵循命名约定,确保重命名numeratorsNumerators和.denominatorsDenominators

但是,如果这不能解决您的模型绑定问题,请详细说明并发布您的模型实现 :)

- 更新

正如您所报告的问题仍然存在,我将根据您自己提供的示例发布我已实现的代码 - 然后您可以交叉检查以确保一切在您的机器上看起来正确 - 下面显示的代码已经过测试并且可以工作:

模型:

public class BetChargeModel
{
    public List<double> numerators { get; set; }
    public List<double> denominators { get; set; }
}

看法:

@model Project.Models.BetChargeModel

@using (Html.BeginForm())
{
<div>
    @Html.TextBoxFor(m=>m.numerators[0])   /   @Html.TextBoxFor(m=>m.denominators[0])
</div>

<div>
    @Html.TextBoxFor(m => m.numerators[1])   /   @Html.TextBoxFor(m => m.denominators[1])
</div>

<div>
    <input type="submit" value="Calculate" />
</div>
}

控制器:

public ActionResult Index()
{
    var model = new BetChargeModel
                    {
                        numerators = new List<double> {0, 0},
                        denominators = new List<double> {1, 1}
                    };
    return View(model);
}

[HttpPost]
public ActionResult Index(BetChargeModel model)
{
    var odds1 = model.numerators[0] / model.denominators[0];
    var odds = model.numerators[1] / model.denominators[1];
    return null;
}
于 2012-10-10T20:31:27.047 回答