У меня есть 3 набора флажков - checkboxDofM
, checkboxMonth
и checkboxDay
. Я хочу проверить, отмечены ли какие-либо из полей checkboxDofM
. Если они есть, то пользователь не должен ставить флажки checkboxDay
. Аналогично, если какой-либо из полей в checkboxDay
установлен, то пользователь не должен иметь возможность выбирать какие-либо из полей checkboxDofM
. Единственная проблема в том, что я не знаю, как это сделать, так как я не могу контролировать идентификатор и имя генерируемых флажков, а функция "checked"
, похоже, не работает. Может ли кто-нибудь помочь мне с этим?
Инструменты разработчика, показывающие, что находится внутри элемента массива, который я получаю

Вот вид:
@using (Html.BeginForm("ScheduleInfo", "Scheduler", FormMethod.Post))
{
Html.EnableClientValidation();
<center>
<div class="col-2">
<ul class="list-group">
<li class="list-group-item-heading list-group-item active">
<h4 class="list-group-item-text">Select the day(s) of the month the task should be set at</h4>
</li>
@Html.HiddenFor(m => m.DofMID)
@Html.DisplayFor(m => m.DofMNo)
@for (int i = 0; i < Model.DofMInfo.Count; i++)
{
<li class="list-group-item" style="display:inline-block">
<div class="checkbox-inline checkboxDofM" id= "checkboxDofM">
@Html.HiddenFor(m => m.DofMInfo[i].DofMID)
@Html.CheckBoxFor(m => m.DofMInfo[i].IsChecked)
@Html.LabelFor(m => m.DofMInfo[i].IsChecked, Model.DofMInfo[i].DofMNo)
</div>
</li>
}
</ul>
</div>
</center>
<center>
<div class="col-2">
<ul class="list-group">
<li class="list-group-item-heading list-group-item active">
<h4 class="list-group-item-text">Select the month(s) the task should be set at</h4>
</li>
@Html.HiddenFor(m => m.monthID)
@Html.DisplayFor(m => m.monthName)
@for (int i = 0; i < Model.MonthInfo.Count; i++)
{
<li class="list-group-item" style="display:inline-block">
<div class="checkbox-inline checkboxMonth" id="checkboxMonth">
@Html.HiddenFor(m => m.MonthInfo[i].monthID)
@Html.CheckBoxFor(m => m.MonthInfo[i].IsChecked)
@Html.LabelFor(m => m.MonthInfo[i].IsChecked, Model.MonthInfo[i].monthName)
</div>
</li>
}
</ul>
</div>
</center>
<center>
<div class="col-3">
<ul class="list-group">
<li class="list-group-item-heading list-group-item active">
<h4 class="list-group-item-text">Select the day(s) the task should be set at</h4>
</li>
@Html.HiddenFor(m => m.dayID)
@Html.DisplayFor(m => m.dayName)
@for (int i = 0; i < Model.DayInfo.Count; i++)
{
<li class="list-group-item" style="display:inline-block">
<div class="checkbox-inline checkboxDay" id="checkboxDay">
@Html.HiddenFor(m => m.DayInfo[i].dayID)
@Html.CheckBoxFor(m => m.DayInfo[i].IsChecked)
@Html.LabelFor(m => m.DayInfo[i].IsChecked, Model.DayInfo[i].dayName)
</div>
</li>
}
</ul>
</div>
</center>
<script type="text/javascript">
var myFunction = function () {
var DofMCheck = Array.from(document.getElementsByClassName("checkbox-inline checkboxDofM"));
console.log(DofMCheck);
}();
</script>
<input type="submit" value="Submit Data" id="btnSubmit" />
}
Вот модель представления:
public class Values
{
public List<object> DayOfMonth { get; set; }
public List<object> Month { get; set; }
public List<object> DaysOfWeek { get; set; }
[Required(ErrorMessage = "Field must not be left blank!")]
[RegularExpression(@"^(,{0,1}(\b\d\b|[0-5][0-9]|\*+)(-\b\d\b|-[0-5][0-9]){0,1})$", ErrorMessage = "Enter a number between 0-59!")]
public object Second { get; set; }
[Required(ErrorMessage = "Enter a number between 0-59!")]
[RegularExpression(@"^(,{0,1}(\b\d\b|[0-5][0-9]|\*+)(-\b\d\b|-[0-5][0-9]){0,1})$", ErrorMessage = "Enter a number between 0-59!")]
public object Minute { get; set; }
[Required(ErrorMessage = "Enter a number between 0-23!")]
[RegularExpression(@"^(,{0,1}(\b\d\b|[0-1][0-9]|[2][0-3]|\*+)(-\b\d\b|-[0-1][0-9]|-[2][0-4]){0,1})$", ErrorMessage = "Enter a number between 0-23!")]
public object Hour { get; set; }
public List<SelectListItem> Jobs { get; set; }
public int Job { get; set; }
public List<Values> DofMInfo { get; set; }
public string DofMNo { get; set; }
public int DofMID { get; set; }
public List<Values> MonthInfo { get; set; }
public int monthID { get; set; }
public string monthName { get; set; }
public List<Values> DayInfo { get; set; }
public int dayID { get; set; }
public string dayName { get; set; }
public bool IsChecked { get; set; }
}
}
Вот контроллер:
public class SchedulerController : Controller
{
// GET: Scheduler
[HttpGet]
public ActionResult SchedulerIndex()
{
List<Values> lst = new List<Values>();
List<Values> lst2 = new List<Values>();
List<Values> lst3 = new List<Values>();
Values val = new Values();
val.Jobs = new List<SelectListItem>();
val.Jobs.Add(new SelectListItem() { Text = "Email", Value = "1", Selected = false });
val.Jobs.Add(new SelectListItem() { Text = "Backup", Value = "2", Selected = false });
val.Jobs.Add(new SelectListItem() { Text = "Start Application", Value = "3", Selected = false });
val.Jobs.Add(new SelectListItem() { Text = "Job4", Value = "4", Selected = false });
val.Jobs.Add(new SelectListItem() { Text = "Job5", Value = "5", Selected = false });
List<Values> month11 = new List<Values>();
month11.Add(new Values { monthID = 0, monthName = "Jan", IsChecked = false });
month11.Add(new Values { monthID = 1, monthName = "Feb", IsChecked = false });
month11.Add(new Values { monthID = 2, monthName = "Mar", IsChecked = false });
month11.Add(new Values { monthID = 3, monthName = "Apr", IsChecked = false });
month11.Add(new Values { monthID = 4, monthName = "May", IsChecked = false });
month11.Add(new Values { monthID = 5, monthName = "Jun", IsChecked = false });
month11.Add(new Values { monthID = 6, monthName = "Jul", IsChecked = false });
month11.Add(new Values { monthID = 7, monthName = "Aug", IsChecked = false });
month11.Add(new Values { monthID = 8, monthName = "Sep", IsChecked = false });
month11.Add(new Values { monthID = 9, monthName = "Oct", IsChecked = false });
month11.Add(new Values { monthID = 10, monthName = "Nov", IsChecked = false });
month11.Add(new Values { monthID = 11, monthName = "Dec", IsChecked = false });
List<Values> day6 = new List<Values>();
day6.Add(new Values { dayID = 0, dayName = "Mon", IsChecked = false });
day6.Add(new Values { dayID = 1, dayName = "Tue", IsChecked = false });
day6.Add(new Values { dayID = 2, dayName = "Wed", IsChecked = false });
day6.Add(new Values { dayID = 3, dayName = "Thu", IsChecked = false });
day6.Add(new Values { dayID = 4, dayName = "Fri", IsChecked = false });
day6.Add(new Values { dayID = 5, dayName = "Sat", IsChecked = false });
day6.Add(new Values { dayID = 6, dayName = "Sun", IsChecked = false });
List<Values> days31 = new List<Values>();
days31.Add(new Values { DofMID = 0, DofMNo = "1", IsChecked = false });
days31.Add(new Values { DofMID = 1, DofMNo = "2", IsChecked = false });
days31.Add(new Values { DofMID = 2, DofMNo = "3", IsChecked = false });
days31.Add(new Values { DofMID = 3, DofMNo = "4", IsChecked = false });
days31.Add(new Values { DofMID = 4, DofMNo = "5", IsChecked = false });
days31.Add(new Values { DofMID = 5, DofMNo = "6", IsChecked = false });
days31.Add(new Values { DofMID = 6, DofMNo = "7", IsChecked = false });
days31.Add(new Values { DofMID = 7, DofMNo = "8", IsChecked = false });
days31.Add(new Values { DofMID = 8, DofMNo = "9", IsChecked = false });
days31.Add(new Values { DofMID = 9, DofMNo = "10", IsChecked = false });
days31.Add(new Values { DofMID = 10, DofMNo = "11", IsChecked = false });
days31.Add(new Values { DofMID = 11, DofMNo = "12", IsChecked = false });
days31.Add(new Values { DofMID = 12, DofMNo = "13", IsChecked = false });
days31.Add(new Values { DofMID = 13, DofMNo = "14", IsChecked = false });
days31.Add(new Values { DofMID = 14, DofMNo = "15", IsChecked = false });
days31.Add(new Values { DofMID = 15, DofMNo = "16", IsChecked = false });
days31.Add(new Values { DofMID = 16, DofMNo = "17", IsChecked = false });
days31.Add(new Values { DofMID = 17, DofMNo = "18", IsChecked = false });
days31.Add(new Values { DofMID = 18, DofMNo = "19", IsChecked = false });
days31.Add(new Values { DofMID = 19, DofMNo = "20", IsChecked = false });
days31.Add(new Values { DofMID = 20, DofMNo = "21", IsChecked = false });
days31.Add(new Values { DofMID = 21, DofMNo = "22", IsChecked = false });
days31.Add(new Values { DofMID = 22, DofMNo = "23", IsChecked = false });
days31.Add(new Values { DofMID = 23, DofMNo = "24", IsChecked = false });
days31.Add(new Values { DofMID = 24, DofMNo = "25", IsChecked = false });
days31.Add(new Values { DofMID = 25, DofMNo = "26", IsChecked = false });
days31.Add(new Values { DofMID = 26, DofMNo = "27", IsChecked = false });
days31.Add(new Values { DofMID = 27, DofMNo = "28", IsChecked = false });
days31.Add(new Values { DofMID = 28, DofMNo = "29", IsChecked = false });
days31.Add(new Values { DofMID = 29, DofMNo = "30", IsChecked = false });
days31.Add(new Values { DofMID = 30, DofMNo = "31", IsChecked = false });
val.MonthInfo = month11;
val.DayInfo = day6;
val.DofMInfo = days31;
ViewBag.lst = lst;
ViewBag.lst2 = lst2;
ViewBag.lst3 = lst3;
return View(val);
}
[HttpPost]
public ActionResult ScheduleInfo(Values model, int Job, string Second, string Minute, string Hour, object DayOfMonth, object Month, object DaysOfWeek)// int DayOfMonth)
{
var secondCon = Convert.ToInt32(Second);
var minuteCon = Convert.ToInt32(Minute);
var hourCon = Convert.ToInt32(Hour);
model.Job = Job;
model.Second = secondCon;
model.Minute = minuteCon;
model.Hour = hourCon;
model.DayOfMonth = new List<object>();
model.Month= new List<object>();
model.DaysOfWeek = new List<object>();
foreach (var dofm in model.DofMInfo)
{
if (dofm.IsChecked)
{
model.DayOfMonth.Add(dofm.DofMID);
}
else if (dofm.IsChecked == false)
{
model.DayOfMonth.Add("?");
}
}
foreach (var month in model.MonthInfo)
{
if (month.IsChecked)
{
model.Month.Add(month.monthID);
}
else if(month.IsChecked)
{
model.Month.Add("*");
}
}
foreach (var day in model.DayInfo)
{
if (day.IsChecked)
{
model.DaysOfWeek.Add(day.dayID);
}
else if (day.IsChecked== false)
{
model.DaysOfWeek.Add("?");
}
}
return RedirectToAction("SchedulerIndex");
}
}
То, что я имел в виду под проверкой не работает, это:
<script>
let checkboxDofMElements = document.getQuerySelectorAll('.checkboxDofM');
for(let i = 0; i < checkboxDofMElements.length; i++)
{
checkboxDofMElements[i].addEventListener('change', function(event)
{
if(this.checked)
{
console.log("Something has changed");
}
else
{
console.log("nothing has changed");
}
});
}
</script>
Когда я добавляю скрипт выше, он должен вернуть «что-то изменилось». Вместо этого он возвращает сообщение «ничего не изменилось».
Как это
