每次有新的模型项时,我都想在 foreach 循环中更改全局 jquery 变量的值。我想在日历中添加新日期,但在我可以从 foreach 循环访问这些函数之前无法做到这一点。
*编辑***
对于vov v正确回答的问题,我过度简化了我的示例。实际代码将做的不仅仅是添加一个值,因为它会将数据添加到日历中。我添加了更多代码来展示它会做得更好
jQuery:
<div id="calendar" style="width: 500px;" />
<script type="text/javascript">
$(document).ready(function () {
var calendar = $('#calendar').glDatePicker(
{
showAlways: true,
borderSize: 0,
dowOffset: 1,
selectableDOW: [1, 2, 3, 4, 5],
selectableYears: [2012, 2013, 2014, 2015],
specialDates: [
{
date: new Date(2013, 0, 8),
data: { message: 'Meeting every day 8 of the month' },
repeatMonth: true
},
{
date: new Date(2013, 5, 7),
data: { message: 'Meeting every day 8 of the month' }
},
],
onClick: function (target, cell, date, data) {
target.val(date.getFullYear() + ' - ' +
date.getMonth() + ' - ' +
date.getDate());
if (data != null) {
alert(data.message + '\n' + date);
}
}
}).glDatePicker(true);
$('#visible').change(function () {
var showAlways = eval($(this).val());
calendar.options.showAlways = showAlways;
if (!showAlways) {
calendar.hide();
}
else {
calendar.show();
}
});
});
var value = 0;
$('#total').click(function () {
alert(value);
});
function add() {
// will eventually add new specialDates to the calendar taken from model items
//test lines
//value = value + 1;
//return value;
}
</script>
剃刀视图:
<input type="button" id="total" />
@foreach (var item in Model){
if (item.AppointmentStatus == "active")
{
// item display code
@: <script type="text/javascript"> add();</script>
}
if (item.AppointmentStatus == "history")
{
// item display code
}
}
我运行它并在下面出现错误,因为它没有看到其他代码
'0x800a1391 - JavaScript 运行时错误:'add' 未定义'