最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - dynamically remove an element's required attribute in ASP MVC? - Stack Overflow

programmeradmin1浏览0评论

Is there a way, in an ASP MVC project using unobtrusive validation, to dynamically remove the Required attribute from an element?

The element is decorated with a Required annotation in the view model. I thought I could remove this by removing the html attribute, "data-val-required," with JQuery but client validation still treats the element as required. Is it impossible to manipulate the element's validation by manipulating the unobtrusive validation attributes?

This is what I tried, but it didn't work. I wanted to remove the required attribute if a check box was unchecked.

$("#chkTempHire").click(function () {

    var checked = $(this).attr("checked");
    var attr = $("#txtTempHireEndDate").attr("data-val-required");
    var hasAttr = false;

    if (typeof attr !== typeof undefined && attr !== false)
        hasAttr = true;

    if (!checked && hasAttr)
        $("#txtTempHireEndDate").removeAttr("data-val-required");
});

Am I missing something, or is it just not possible?

Thank you!

Is there a way, in an ASP MVC project using unobtrusive validation, to dynamically remove the Required attribute from an element?

The element is decorated with a Required annotation in the view model. I thought I could remove this by removing the html attribute, "data-val-required," with JQuery but client validation still treats the element as required. Is it impossible to manipulate the element's validation by manipulating the unobtrusive validation attributes?

This is what I tried, but it didn't work. I wanted to remove the required attribute if a check box was unchecked.

$("#chkTempHire").click(function () {

    var checked = $(this).attr("checked");
    var attr = $("#txtTempHireEndDate").attr("data-val-required");
    var hasAttr = false;

    if (typeof attr !== typeof undefined && attr !== false)
        hasAttr = true;

    if (!checked && hasAttr)
        $("#txtTempHireEndDate").removeAttr("data-val-required");
});

Am I missing something, or is it just not possible?

Thank you!

Share Improve this question edited Jul 17, 2015 at 3:28 Daniel Hoffmann-Mitscherling 2,3791 gold badge17 silver badges23 bronze badges asked Jul 16, 2015 at 23:04 MikeMike 4092 gold badges11 silver badges20 bronze badges 3
  • 3 One solution is to use MVC's Foolproof Validation, which allows you to use attributes such as RequiredIf. – Icemanind Commented Jul 16, 2015 at 23:12
  • 2 Conditional validation is what you're looking for, for example: stackoverflow.com/questions/17970584/… – Nico Commented Jul 16, 2015 at 23:22
  • Thanks, I am using FluentValidation and it works for me. I've just been trying to learn more about how the unobtrusive validation works. – Mike Commented Jul 17, 2015 at 17:43
Add a comment  | 

4 Answers 4

Reset to default 30

You can use the .rules() method built into jQuery, you don't need to manually remove attributes.

To remove:

$("#txtTempHireEndDate").rules("remove", "required")

To add:

$("#txtTempHireEndDate").rules("add", "required")

you can use rules function in jquery.validate

$("..").rules("add",....)
$("..").rules("remove",...)

http://jqueryvalidation.org/rules

You must revalidate the form.

Just call the validate function from form, like this:

$('#FormId').valid();

You can also validate the control you've removed the attribute:

$('#txtTempHireEndDate').valid();

$("#dailyFlow").removeAttr('data-val-required');

发布评论

评论列表(0)

  1. 暂无评论