- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我要添加两个或多个实体,我必须在单个类中声明所有属性,以便将它们从 Ajax 调用中的 View 正确映射到 JS。
只是检查一下我是否遗漏了 AutoMapper 可以做但我没有利用的东西...
例如,如果仅使用一个实体(客户),则 AutoMapper 中的以下内容可以正常工作:
Mapper.CreateMap<CustomerDTO, Customer>();
var customer = Mapper.Map<CustomerDTO, Customer>(custDTO);
如果使用两个或多个实体,我必须执行以下操作:
using (var dbcxtTrans = DbContext.Database.BeginTransaction(System.Data.IsolationLevel.RepeatableRead))
{
Customer cust = new Customer();
cust.Address1 = custProjDTO.customer_Address1;
cust.Address2 = custProjDTO.customer_Address2;
cust.CellPhone = custProjDTO.customer_CellPhone;
cust.City = custProjDTO.customer_City;
cust.Company = custProjDTO.customer_Company;
cust.CreatedDate = custProjDTO.customer_CreatedDate;
cust.Email = custProjDTO.customer_Email;
cust.FirstName = custProjDTO.customer_FirstName;
cust.HomePhone = custProjDTO.customer_HomePhone;
cust.IMAddress = custProjDTO.customer_IMAddress;
cust.LastName = custProjDTO.customer_LastName;
cust.State = custProjDTO.customer_State;
cust.UpdatedDate = custProjDTO.customer_UpdatedDate;
cust.UserName = custProjDTO.customer_UserName;
cust.Website = custProjDTO.customer_Website;
cust.Zip = custProjDTO.customer_Zip;
DbContext.Customers.Add(cust);
await DbContext.SaveChangesAsync();
Project proj = new Project();
proj.CustomerID = cust.CustomerID;
proj.CategoryID = custProjDTO.project_CategoryID;
proj.CreatedDate = custProjDTO.project_CreatedDate;
proj.Description = custProjDTO.project_Description;
proj.Name = custProjDTO.project_Name;
proj.Notes = custProjDTO.project_Notes;
proj.PriorityID = custProjDTO.project_PriorityID;
proj.Quote = custProjDTO.project_Quote;
proj.StatusID = custProjDTO.project_StatusID;
proj.UpdatedDate = custProjDTO.project_UpdatedDate;
DbContext.Projects.Add(proj);
await DbContext.SaveChangesAsync();
dbcxtTrans.Commit();
}
这是因为我的属性名称必须与 View 中的名称对齐(见下文)
@model YeagerTechDB.ViewModels.Customers.CustomerProject
@{
ViewBag.Title = "Create Customer & Project";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Create</h2>
<div class="body-content">
<h4>Customer/Project</h4>
<hr />
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
<fieldset>
<legend>Customer</legend>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-11 col-md-11 col-sm-11 col-xs-11">
@Html.EditorFor(model => model.customer_UserName, new { htmlAttributes = new { @class = "form-control", @placeholder = "UserName" } })
@Html.ValidationMessageFor(model => model.customer_UserName, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-md-11 col-sm-11 col-xs-11">
@Html.EditorFor(model => model.customer_Email, new { htmlAttributes = new { @class = "form-control", @placeholder = "Email" } })
@Html.ValidationMessageFor(model => model.customer_Email, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-11 col-md-11 col-sm-11 col-xs-11">
@Html.EditorFor(model => model.customer_Company, new { htmlAttributes = new { @class = "form-control", @placeholder = "Company" } })
@Html.ValidationMessageFor(model => model.customer_Company, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-5 col-md-5 col-sm-5 col-xs-5">
@Html.EditorFor(model => model.customer_FirstName, new { htmlAttributes = new { @class = "form-control", @placeholder = "First Name" } })
@Html.ValidationMessageFor(model => model.customer_FirstName, "", new { @class = "text-danger" })
</div>
<div class="col-lg-5 col-md-5 col-sm-5 col-xs-5">
@Html.EditorFor(model => model.customer_LastName, new { htmlAttributes = new { @class = "form-control", @placeholder = "Last Name" } })
@Html.ValidationMessageFor(model => model.customer_LastName, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-11 col-md-11 col-sm-11 col-xs-11">
@Html.EditorFor(model => model.customer_Address1, new { htmlAttributes = new { @class = "form-control", @placeholder = "Address1" } })
@Html.ValidationMessageFor(model => model.customer_Address1, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-11 col-md-11 col-sm-11 col-xs-11">
@Html.EditorFor(model => model.customer_Address2, new { htmlAttributes = new { @class = "form-control", @placeholder = "Address2" } })
@Html.ValidationMessageFor(model => model.customer_Address2, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-md-5 col-sm-5 col-xs-5">
@Html.EditorFor(model => model.customer_City, new { htmlAttributes = new { @class = "form-control", @placeholder = "City" } })
@Html.ValidationMessageFor(model => model.customer_City, "", new { @class = "text-danger" })
</div>
<div class="col-md-2 col-sm-2 col-xs-2">
@Html.EditorFor(model => model.customer_State, new { htmlAttributes = new { @class = "form-control", @placeholder = "State" } })
@Html.ValidationMessageFor(model => model.customer_State, "", new { @class = "text-danger" })
</div>
<div class="col-md-3 col-sm-3 col-xs-3">
@Html.EditorFor(model => model.customer_Zip, new { htmlAttributes = new { @class = "form-control", @placeholder = "Zip" } })
@Html.ValidationMessageFor(model => model.customer_Zip, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-5 col-md-5 col-sm-5 col-xs-5">
@Html.EditorFor(model => model.customer_HomePhone, new { htmlAttributes = new { @class = "form-control", @placeholder = "Home Phone" } })
@Html.ValidationMessageFor(model => model.customer_HomePhone, "", new { @class = "text-danger" })
</div>
<div class="col-lg-5 col-md-5 col-sm-5 col-xs-5">
@Html.EditorFor(model => model.customer_CellPhone, new { htmlAttributes = new { @class = "form-control", @placeholder = "Cell Phone" } })
@Html.ValidationMessageFor(model => model.customer_CellPhone, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-5 col-md-5 col-sm-5 col-xs-5">
@Html.EditorFor(model => model.customer_Website, new { htmlAttributes = new { @class = "form-control", @placeholder = "Website" } })
@Html.ValidationMessageFor(model => model.customer_Website, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-5 col-md-5 col-sm-5 col-xs-5">
@Html.EditorFor(model => model.customer_IMAddress, new { htmlAttributes = new { @class = "form-control", @placeholder = "IM Address" } })
@Html.ValidationMessageFor(model => model.customer_IMAddress, "", new { @class = "text-danger" })
</div>
</div>
</fieldset>
<fieldset>
<legend>Project</legend>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-4 col-md-4 col-sm-4 col-xs-4">
@Html.EditorFor(model => model.project_Name, new { htmlAttributes = new { @class = "form-control", @placeholder = "ProjectName" } })
@Html.ValidationMessageFor(model => model.project_Name, "", new { @class = "text-danger" })
</div>
<div class="col-lg-7 col-md-7 col-sm-7 col-xs-7">
@Html.EditorFor(model => model.project_Description, new { htmlAttributes = new { @class = "form-control", @placeholder = "Description" } })
@Html.ValidationMessageFor(model => model.project_Description, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-3 col-md-3 col-sm-3 col-xs-3">
@Html.DropDownListFor(model => model.project_CategoryID, new SelectList(ViewBag.Categories, "CategoryID", "CategoryDescription"), "-- Select Category --", new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.project_CategoryID, "", new { @class = "text-danger" })
</div>
<div class="col-lg-3 col-md-3 col-sm-3 col-xs-3">
@Html.DropDownListFor(model => model.project_PriorityID, new SelectList(ViewBag.Priorities, "PriorityID", "PriorityDescription"), "-- Select Priority --", new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.project_PriorityID, "", new { @class = "text-danger" })
</div>
<div class="col-lg-3 col-md-3 col-sm-3 col-xs-3">
@Html.DropDownListFor(model => model.project_StatusID, new SelectList(ViewBag.Statuses, "StatusID", "StatusDescription"), "-- Select Status --", new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.project_StatusID, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-10 col-md-10 col-sm-10 col-xs-10">
@Html.EditorFor(model => model.project_Quote, new { htmlAttributes = new { @class = "form-control", @placeholder = "Quote" } })
@Html.ValidationMessageFor(model => model.project_Quote, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-lg-offset-1 col-md-offset-1 col-sm-offset-1 col-xs-offset-1 col-lg-10 col-md-10 col-sm-10 col-xs-10">
@Html.EditorFor(model => model.project_Notes, new { htmlAttributes = new { @class = "form-control", @placeholder = "Notes" } })
@Html.ValidationMessageFor(model => model.project_Notes, "", new { @class = "text-danger" })
</div>
</div>
</fieldset>
<div class="form-group">
<div>
<button type="submit" id="btnCustomerProjectCreate" class="btn btn-default col-offset-2"><span class="glyphicon glyphicon-save"></span>Create</button>
</div>
</div>
</div>
<div>
@Html.ActionLink("Back to List", "Index")
@Html.Hidden("customerprojectCreateUrl", Url.Action("Create", "CustomerProjects", new { area = "Customers" }))
</div>
@section Scripts {
<script>
$(document).ready(function ()
{
if (typeof contentCreateCustomerProject == "function")
contentCreateCustomerProject();
});
</script>
}
反过来,它必须与我的 JS 属性保持一致:
var customerProject_Input = {
customer_UserName: $('#customer_UserName').val(),
customer_Email: $('#customer_Email').val(),
customer_Company: $('#customer_Company').val(),
customer_FirstName: $('#customer_FirstName').val(),
customer_LastName: $('#customer_LastName').val(),
customer_Address1: $('#customer_Address1').val(),
customer_Address2: $('#customer_Address2').val(),
customer_City: $('#customer_City').val(),
customer_State: $('#customer_State').val(),
customer_Zip: $('#customer_Zip').val(),
customer_HomePhone: $('#customer_HomePhone').val(),
customer_CellPhone: $('#customer_CellPhone').val(),
customer_Website: $('#customer_Website').val(),
customer_IMAddress: $('#customer_IMAddress').val(),
customer_CreatedDate: currdate,
customer_UpdatedDate: null,
project_Name: $('#project_Name').val(),
project_Description: $('#project_Description').val(),
project_CategoryID: $('#project_CategoryID').val(),
project_PriorityID: $('#project_PriorityID').val(),
project_StatusID: $('#project_StatusID').val(),
project_Quote: $('#project_Quote').val(),
project_Notes: $('#project_Notes').val(),
project_CreatedDate: currdate,
project_UpdatedDate: null
};
反过来,它只能在一个类中定义(见下文):
using System;
using System.ComponentModel.DataAnnotations;
using System.Runtime.Serialization;
namespace YeagerTechDB.ViewModels.Customers
{
[Serializable, DataContract(IsReference = true)]
public class CustomerProject
{
//Customer
[ScaffoldColumn(true)]
[Display(Name = "ID")]
[DataMember]
public short customer_CustomerID { get; set; }
[Required]
[StringLength(256)]
[DataMember]
public string customer_UserName { get; set; }
[Required]
[StringLength(50)]
[EmailAddress]
[DataMember]
public string customer_Email { get; set; }
[StringLength(50)]
[DataMember]
public string customer_Company { get; set; }
[StringLength(50)]
[DataMember]
public string customer_FirstName { get; set; }
[StringLength(50)]
[DataMember]
public string customer_LastName { get; set; }
[StringLength(50)]
[DataMember]
public string customer_Address1 { get; set; }
[StringLength(50)]
[DataMember]
public string customer_Address2 { get; set; }
[StringLength(50)]
[DataMember]
public string customer_City { get; set; }
[StringLength(2)]
[DataMember]
public string customer_State { get; set; }
[StringLength(10)]
[DataType(DataType.PostalCode)]
[RegularExpression(@"^\d{5}(-\d{4})?$", ErrorMessage = "Must match 99999 or 99999-9999 format")]
[DataMember]
public string customer_Zip { get; set; }
[StringLength(12)]
[DataType(DataType.PhoneNumber)]
[RegularExpression(@"^\s*([\(]?)\[?\s*\d{3}\s*\]?[\)]?\s*[\-]?[\.]?\s*\d{3}\s*[\-]?[\.]?\s*\d{4}$", ErrorMessage = "Must match 999-999-9999 format")]
[DataMember]
public string customer_HomePhone { get; set; }
[StringLength(12)]
[DataType(DataType.PhoneNumber)]
[RegularExpression(@"^\s*([\(]?)\[?\s*\d{3}\s*\]?[\)]?\s*[\-]?[\.]?\s*\d{3}\s*[\-]?[\.]?\s*\d{4}$", ErrorMessage = "Must match 999-999-9999 format")]
[DataMember]
public string customer_CellPhone { get; set; }
[StringLength(100)]
[DataType(DataType.Url)]
[DataMember]
public string customer_Website { get; set; }
[StringLength(50)]
[DataType(DataType.Url)]
[DataMember]
public string customer_IMAddress { get; set; }
[DataType(DataType.DateTime)]
[Display(Name = "Created")]
[DataMember]
public DateTime customer_CreatedDate { get; set; }
[Display(Name = "Updated")]
[DataType(DataType.DateTime)]
[DataMember]
public DateTime? customer_UpdatedDate { get; set; }
//Project
[ScaffoldColumn(false)]
[Editable(false)]
[Display(Name = "Proj ID")]
[DataMember]
public short project_ProjectID { get; set; }
[ScaffoldColumn(false)]
[Editable(true)]
[Display(Name = "Cust ID")]
[DataMember]
public short project_CustomerID { get; set; }
[Required(ErrorMessage = "Required!")]
[StringLength(30)]
[Display(Name = "Project Name")]
[DataMember]
public string project_Name { get; set; }
[Required]
[DataType(DataType.MultilineText)]
[DataMember]
public string project_Description { get; set; }
[ScaffoldColumn(true)]
[Display(Name = "Category")]
[DataMember]
public short project_CategoryID { get; set; }
[ScaffoldColumn(true)]
[Display(Name = "Priority")]
[DataMember]
public short project_PriorityID { get; set; }
[ScaffoldColumn(true)]
[Display(Name = "Status")]
[DataMember]
public short project_StatusID { get; set; }
[DataType(DataType.Currency)]
[DataMember]
public decimal? project_Quote { get; set; }
[DataType(DataType.MultilineText)]
[DataMember]
public string project_Notes { get; set; }
[DataType(DataType.DateTime)]
[Display(Name = "Created")]
[DataMember]
public DateTime project_CreatedDate { get; set; }
[DataType(DataType.DateTime)]
[Display(Name = "Updated")]
[DataMember]
public DateTime? project_UpdatedDate { get; set; }
}
}
最佳答案
由于两个类中的属性名称不同,请尝试创建详细的映射配置,例如:
Mapper.CreateMap<Customer, CustomerDTO>()
.ForMember(dest => dest.Address1,
opts => opts.MapFrom(src => src.customer_Address1))
.ForMember(dest => dest.Address2,
opts => opts.MapFrom(src => src.customer_Address2))
.ForMember(dest => dest.CellPhone,
opts => opts.MapFrom(src => src.customer_CellPhone))
.ForMember(dest => dest.City,
opts => opts.MapFrom(src => src.customer_City))
.ForMember(dest => dest.Company,
opts => opts.MapFrom(src => src.customer_Company))
.ForMember(dest => dest.CreatedDate,
opts => opts.MapFrom(src => src.customer_CreatedDate))
.ForMember(dest => dest.Email,
opts => opts.MapFrom(src => src.customer_Email))
.ForMember(dest => dest.FirstName,
opts => opts.MapFrom(src => src.customer_FirstName))
.ForMember(dest => dest.HomePhone,
opts => opts.MapFrom(src => src.customer_HomePhone))
.ForMember(dest => dest.IMAddress,
opts => opts.MapFrom(src => src.customer_IMAddress))
.ForMember(dest => dest.LastName,
opts => opts.MapFrom(src => src.customer_LastName))
.ForMember(dest => dest.State,
opts => opts.MapFrom(src => src.customer_State))
.ForMember(dest => dest.UpdatedDate,
opts => opts.MapFrom(src => src.customer_UpdatedDate))
.ForMember(dest => dest.UserName,
opts => opts.MapFrom(src => src.customer_UserName))
.ForMember(dest => dest.Website,
opts => opts.MapFrom(src => src.customer_Website))
.ForMember(dest => dest.Zip,
opts => opts.MapFrom(src => src.customer_Zip));
此外,为了保存对象,您不需要调用以下两次:
await DbContext.SaveChangesAsync();
只做一次:
DbContext.Projects.Add(proj);
DbContext.Customers.Add(cust);
await DbContext.SaveChangesAsync();
关于javascript - 如果使用单个实体,使用自动映射器对我来说效果很好,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28551717/
我想做的是,如果鼠标位于“下一个”按钮上,它会以慢速向右滚动,如果鼠标没有位于“下一个”按钮上,它会停止滚动? 这是我的尝试http://jsfiddle.net/mdanz/nCCRy/14/ $(
StyleCop 是一个很棒的视觉工作室小插件。但它不会向您显示实时提示或提供任何自动修复。 随之而来的是 reSharper 和 StyleCop for reSharper,这是理想的解决方案,但
我为我的MatchQuery使用了模糊性选项,但是我想将模糊性值设置为auto。有什么办法吗? 另外,对于完成建议程序,您可以将其设置为支持unicode,对于我的MatchQuery,有什么方法可以
我想从表中获取一行[字符串名称,字符串密码,int 某些内容]并将其映射到一个 User 对象,该对象具有 3 个属性,如上面的 getter 和 setter有什么方法可以自动完成吗?我考虑过反射,
我有一个像这样的方法:void m1(string str) 并且有一个像这样的类: public class MyClass { public bool b1 { set; get; }
我正在尝试使用 $rootScope 从一个 Controller 向另一个 Controller $broadcast 一些数据。 如果我使用像 ng-click 这样的触发器来运行将广播的功能,它
我考虑了很多关于是要使用完全自动化的缓存还是手动缓存。 我们的自动方法是一种解决方案,它可以挖掘数据库、查询和格式化每个潜在和 future 的数据请求,并将其保存到适当的缓存存储(内存缓存或基于磁盘
我的 CSS 必须使用过渡来更改,直到现在我都使用 div:hover 来实现。 当您单击另一个 div 时需要激活过渡,而不是当您将鼠标悬停在必须移动/更改的 div 上时。 我该怎么做? 谢谢 永
在我的应用程序中,我需要一些动画,但如果它已经设置了动画,则不需要持续时间。但我的问题是它会自动添加持续时间。 在这里你可以看到 2 个函数,第二个没有持续时间但它确实有持续时间(可能从 1 秒开始)
两年前,我需要制作一个工具,通过 POST 自动将 txt/csv 文件上传到我的 Web 服务器,然后使用 cronjob 通过 PHP 对其进行解析。 这有两次在每天午夜自动发生。尽管这行得通,但
请阅读下面程序中的评论: #include void test(char c[]) { c=c+2; //why does this work ? c--; printf("%
也许是个幼稚的问题,但是...... 确认或拒绝: 自动和静态存储持续时间的对象/变量的内存的存在是在编译时确定的,程序运行时失败的可能性绝对为零,因为没有足够的内存用于自动对象。 自然地,当自动对象
有没有什么方法可以自动获得类中属性更改的通知,而不必在每个 setter 中都编写 OnPropertyChanged? (我有数百个属性,我想知道它们是否已更改)。 安东建议 dynamic pro
我们在使用 Azure DevOps 的项目中采用了 gitflow 流程。我有以下场景: 当功能分支合并到 Develop 时,我想在完成拉取请求的同时执行压缩合并策略 当 Release 分支定期
我的网站上有一个评论部分,我将 html 编码的评论保存在我的数据库中。所以我添加了这条评论- "testing" `quotes` \and backslashes\ and html 并将其保存在
是否存在“ checkin 前 TFS 自动 checkout ”这样的功能,以便在我说“ checkin ”之前我不会 checkout 任何文件,例如以防我只是临时更改文件 - 这一直发生。 换句
我有一个运行在 Linux/Apache/Tomcat 堆栈上的网站,它需要每隔几个月自动脱机以进行服务器维护,这将持续任意时间。有哪些选项可以让 Apache 建立和取消“服务器维护”页面? 我需要
我经常在工作中创建文档,在公司内部,由于我们使用的首字母缩写词和缩写词的数量,我们几乎拥有自己的语言。因此,我厌倦了在发布文档之前手动创建首字母缩写词和缩写表,并且快速的谷歌搜索发现了一个可以有效地为
我希望在用户或宏将计算模式从自动更改为手动或手动更改为自动时运行代码。是否有为此触发的事件? (属性是 Application.Calculation 在 Excel 互操作中。) 使用 Excel
这个问题在这里已经有了答案: Repeat command automatically in Linux (13 个回答) 6年前关闭。 我想创建一个脚本来获取另一个文件夹中的所有文件夹名称。并为这些
我是一名优秀的程序员,十分优秀!