ASP.NET剃须刀:表单未提交

时间:2012-04-24 09:17:02

标签: c# asp.net asp.net-mvc forms razor

由于我在我的DateTime属性/输入字段中添加了一个DisplayFormat和datepicker,我的表单停止了提交。我没有任何错误(在Chrome F12或Visual studio中)。

编辑:我将Displayformat设置为dd / MM / yyyy,将datepicker设置为“dd / mm / yyyy”。但这也没有解决它。

@using (Html.BeginForm("CreateCampaign", "Home")) {
    @Html.ValidationSummary(true)
    <fieldset>
        <legend>Campaign</legend>
        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.CampaignName)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.CampaignName)
            @Html.ValidationMessageFor(model => model.Campaign.CampaignName)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.WebsiteUrl)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.WebsiteUrl)
            @Html.ValidationMessageFor(model => model.Campaign.WebsiteUrl)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.PrivacyPolicyUrl)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.PrivacyPolicyUrl)
            @Html.ValidationMessageFor(model => model.Campaign.PrivacyPolicyUrl)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.TermsUrl)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.TermsUrl)
            @Html.ValidationMessageFor(model => model.Campaign.TermsUrl)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.PricepageUrl)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.PricepageUrl)
            @Html.ValidationMessageFor(model => model.Campaign.PricepageUrl)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.Startdate)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.Startdate)
            @Html.ValidationMessageFor(model => model.Campaign.Startdate)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.Enddate)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.Enddate)
            @Html.ValidationMessageFor(model => model.Campaign.Enddate)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.Starthour)
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(model => model.Campaign.Starthour, new SelectList(Model.Hours))
            @Html.ValidationMessageFor(model => model.Campaign.Starthour)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.Endhour)
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(model => model.Campaign.Endhour, new SelectList(Model.Hours))
            @Html.ValidationMessageFor(model => model.Campaign.Endhour)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.PMAM)
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(model => model.Campaign.PMAM, new SelectList(Model.AMPM, "key", "value"))
            @Html.ValidationMessageFor(model => model.Campaign.PMAM)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.Language)
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(model => model.Campaign.Language, new SelectList(Model.Languages, "key", "value"))
            @Html.ValidationMessageFor(model => model.Campaign.Language)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.FK_ID_MerchantApp)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Campaign.FK_ID_MerchantApp)
            @Html.ValidationMessageFor(model => model.Campaign.FK_ID_MerchantApp)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Campaign.CampaignType)
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(model => model.Campaign.CampaignType, new SelectList(Model.Types, "key", "value"))
            @Html.ValidationMessageFor(model => model.Campaign.CampaignType)
        </div>
        <p>
            <input type="submit" value="Create" />
        </p>
    </fieldset>
}
<script type="text/javascript">
    $('#Campaign_Startdate').datepicker({
        dateFormat: "DD, d MM, yy",
        minDate: new Date()
    });
    $('#Campaign_Enddate').datepicker({
        dateFormat: "DD, d MM, yy",
        minDate: new Date()
    });

</script>
<div>
    @Html.ActionLink("Back to List", "Index")
</div>




       public class Campaign
        {
            #region CTor
            public Campaign()
            {
            }
            #endregion

            #region Properties

            [XmlElement(ElementName = "Id_campaign")]
            public string ID_Campaign { get; set; }
            [XmlElement(ElementName = "Campaignname")]
            public string CampaignName { get; set; }
            [XmlElement(ElementName = "Websiteurl")]
            public string WebsiteUrl { get; set; }
            [XmlElement(ElementName = "Privacypolicyurl")]
            public string PrivacyPolicyUrl { get; set; }
            [XmlElement(ElementName = "Termsurl")]
            public string TermsUrl { get; set; }
            [XmlElement(ElementName = "Pricepageurl")]
            public string PricepageUrl { get; set; }
            [XmlElement(ElementName = "Maxcredit")]
            public Int32 MaxCredit { get; set; }
            [XmlElement(ElementName = "Fk_id_currency")]
            public string FK_ID_Currency { get; set; }
            [XmlElement(ElementName = "Maxscans")]
            public short MaxScans { get; set; }
            [XmlElement(ElementName = "Startdate")]
            [DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:ddd, MMM d, yyyy}")]
            public DateTime Startdate { get; set; }
            [XmlElement(ElementName = "Enddate")]
            [DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:ddd, MMM d, yyyy}")]
            public DateTime Enddate { get; set; }
            [XmlElement(ElementName = "Starthour")]
            public short Starthour { get; set; }
            [XmlElement(ElementName = "Endhour")]
            public short Endhour { get; set; }
            [XmlElement(ElementName = "Pmam")]
            public string PMAM { get; set; }
            [XmlElement(ElementName = "Language")]
            public string Language { get; set; }
            [XmlElement(ElementName = "Fk_id_merchantapp")]
            public string FK_ID_MerchantApp { get; set; }
            [XmlElement(ElementName = "Campaigntype")]
            public string CampaignType { get; set; }
            [XmlElement(ElementName = "Createtimestamp")]
            [DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:ddd, MMM d, yyyy}")]
            public DateTime CreateTimestamp { get; set; }
            [XmlElement(ElementName = "Lastupdate")]
            [DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:ddd, MMM d, yyyy}")]
            public DateTime LastUpdate { get; set; }
            [XmlElement(ElementName = "Lastupdateby")]
            public string LastUpdateBy { get; set; }
            [XmlElement(ElementName = "Status")]
            public short Status { get; set; }
    }

3 个答案:

答案 0 :(得分:3)

我看到您将验证摘要设置为true。可能是不显眼的验证会阻止您的表单被提交而且您无法看到它,因为错误未附加到特定字段?也许,尝试将其设置为false,并查看是否有任何弹出?您有unobtrusive validation turned on以及客户端验证吗?

您是否使用chrome的网络工具检查提交后是否发送了任何http帖子?您是否尝试在模型中使用“dd / mm / yyyy”?

答案 1 :(得分:1)

您没有表格。用Html.BeginForm包装它:

 @{ using (Html.BeginForm()) { 




              ....




    }
 }

答案 2 :(得分:1)

这可能听起来太明显了,但是因为它在你添加'datepicker'之后停止了工作,并且你正在使用jQuery,你应该尝试添加

$(document).ready(function() {

});

包装你的'datepicker'代码。