【问题标题】:How Auto Implemented Get property returns specific data memberAuto Implemented Get 属性如何返回特定的数据成员
【发布时间】:2014-07-27 21:41:10
【问题描述】:

首先我想告诉大家,我已经花了 3 天时间阅读材料和观看教程,但仍然很难理解这个概念!请帮助我了解当您有多个数据成员时,类的自动实现属性如何决定返回哪个数据成员。以下是一段代码,它使用实体框架从 SQL(一个有 3 列的表;Id(int-即 PK)、Name(nvarchar)和 IsSelected(bit))服务器中提取简单数据并生成单选按钮。当您选择每个单选按钮并点击提交时,它会告诉您您选择了哪个部门 (ID)。

我的问题是,在此上下文中还有 2 个其他数据成员,自动实现的 Get 方法 SelectedDepartment 是如何计算出 Id 字段的?

SQL 服务器中的 Id 数据类型也是 int,但是为 SelectedDepartment 定义的数据类型是字符串!它是如何工作的

非常感谢任何帮助!

模型(Company.cs);

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace RadioButton.Models
{
    public class Company
    {
        public string SelectedDepartment { get; set; }
        public List<Department> Departments
        {
            get
            {
                SampleContext db = new SampleContext();
                return db.Departments.ToList();
            }
        }

    }
}

控制器;

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using RadioButton.Models;

namespace RadioButton.Controllers
{
    public class HomeController : Controller
    {
        private SampleContext db = new SampleContext();

        //
        // GET: /Home/
        [HttpGet]
        public ActionResult Index()
        {
            Company company = new Company();
            return View(company);
        }
        [HttpPost]
        public string Index(Company company)
        {
            if(string.IsNullOrEmpty(company.SelectedDepartment))
            {
                return "You didn't select any";
            }
            else
            {
                return "you have selected " + company.SelectedDepartment;
            }
        }

        //
        // GET: /Home/Details/5

        public ActionResult Details(int id = 0)
        {
            Department department = db.Departments.Find(id);
            if (department == null)
            {
                return HttpNotFound();
            }
            return View(department);
        }

        //
        // GET: /Home/Create

        public ActionResult Create()
        {
            return View();
        }

        //
        // POST: /Home/Create

        [HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult Create(Department department)
        {
            if (ModelState.IsValid)
            {
                db.Departments.Add(department);
                db.SaveChanges();
                return RedirectToAction("Index");
            }

            return View(department);
        }

        //
        // GET: /Home/Edit/5

        public ActionResult Edit(int id = 0)
        {
            Department department = db.Departments.Find(id);
            if (department == null)
            {
                return HttpNotFound();
            }
            return View(department);
        }

        //
        // POST: /Home/Edit/5

        [HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult Edit(Department department)
        {
            if (ModelState.IsValid)
            {
                db.Entry(department).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View(department);
        }

        //
        // GET: /Home/Delete/5

        public ActionResult Delete(int id = 0)
        {
            Department department = db.Departments.Find(id);
            if (department == null)
            {
                return HttpNotFound();
            }
            return View(department);
        }

        //
        // POST: /Home/Delete/5

        [HttpPost, ActionName("Delete")]
        [ValidateAntiForgeryToken]
        public ActionResult DeleteConfirmed(int id)
        {
            Department department = db.Departments.Find(id);
            db.Departments.Remove(department);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        protected override void Dispose(bool disposing)
        {
            db.Dispose();
            base.Dispose(disposing);
        }
    }
}

查看;

@model RadioButton.Models.Company

@{
    ViewBag.Title = "Index";
}

<h2>Index</h2>

@using (Html.BeginForm())
{
    foreach(var department in Model.Departments)
    {
        @Html.RadioButtonFor(m => m.SelectedDepartment, department.Id) @department.Name
    }
    <br />
    <br />
    <input type="submit" value="submit" />
}

【问题讨论】:

  • 如果你问我认为你在问什么,@Html.RadioButtonFor(m =&gt; m.SelectedDepartment, department.Id) 是这里的主要声明。
  • @JoachimIsaksson 谢谢你,这是否意味着 SelectedDepartment 属性一旦实例化就会包含其中的所有成员?然后我们可以在视图中使用我们想要的任何成员?

标签: c# asp.net-mvc radio-button


【解决方案1】:

属性只是值访问器;他们很笨,也就是说,这里没有魔法。最基本的属性基本上就是这段代码:

private string someProperty;
public string SomeProperty
{
    get { return someProperty; }
    set { someProperty = value; }
}

C# 中所有自动实现的属性只需在后台将public string SomeProperty { get; set; } 转换为上面的代码即可。无法访问该类上的任何其他属性,并且该属性不知道该类上的任何其他属性,也不关心。

Html.RadioButtonFor 接受一个属性(通过表达式)和一个值,并使用它来构造无线电输入。最初,SelectedDepartment 属性的实际值为 null,但 Html.RadioButtonFor 不是查看其值,而是您在第二个参数中作为 HTML 输入的 value 属性提供的值。在这种情况下,您使用的是Id 属性,但这并不重要。同时,HTML 输入的name 值设置为“SelectedDepartment”,因为这是您告诉它绑定的属性。

现在,当您回发时,输入 的值作为SelectedDepartment 的值发送。它不知道也不关心该值最初来自 Id 属性。您也可以轻松做到:

@Html.RadioButtonFor(m => m.SelectedDepartment, "foo")

SelectedDepartment 在回发时的值将是“foo”。关键是与值最初来自哪里没有直接关联,只是它是发布时 HTML 输入的值。

【讨论】:

  • 非常感谢您的详细回答!非常感谢
  • 现在,如果我想包含其他数据成员怎么办!让我们说名称和 ID!我试过 @Html.RadioButtonFor(m => m.SelectedDepartment, department.Id , department.Name) 它不接受!
  • 第二个参数只是一个值类型。您不能包含多个属性,因为对于该输入,只会回发一个值。您可以连接这些值(即department.Id.ToString() + department.Name),但我认为这不是您要在这里寻找的。​​span>
  • 基本上,这归结为简单的 HTML。您的课程和 HTML 页面之间没有强链接。 Razor 只是呈现 HTML,然后将其发送到客户端。客户端发回一些数据,然后由模型绑定器解释。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-08-27
  • 2013-09-22
  • 2019-09-03
  • 2017-04-03
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多