У меня серьезные проблемы с попыткой включить javascript в частичное представление с помощью asp mvc 4, читая этот пост Я следовал инструкциям, чтобы создать пользовательский помощник Html, чтобы включить js. К сожалению, либо я вызываю его из макета, а затем метод фактического включения Javascript никогда не вызывается вовремя (это означает, что запрос страницы уже был вызван, когда я делаю запрос ajax), либо я пытаюсь включить его в свой частичный View, но частичные представления, кажется, автоматически удаляют любой написанный в них javascript. Поэтому я попытался отобразить стандартное представление, но даже это не решило проблему. Дело в том, возможно ли вообще отображать javascript в представлении, вызываемом с помощью ajax в asp mvc? Кто-нибудь делал, подскажите. На самом деле мне нужно запустить javascript в моем представлении «вызывается ajax», потому что я должен обнаруживать значения внутри формы, которая находится внутри этого представления. Я не буду публиковать код помощника, потому что он полностью взят из упомянутого поста. Спасибо!
Хорошо, я постараюсь быть более конкретным, почему я думаю, что мне нужен javascript в моем конкретном представлении. Ниже приведен код основного представления:
@model MvcCursosSSP.Models.CursosModel
@using System.Threading;
@{
ViewBag.Title = "AgregarHorario";
Layout = "~/Views/Shared/_Layout.cshtml";
int numhoras = ViewBag.NumeroHoras;
int dias = ViewBag.Dias;
System.Globalization.CultureInfo culture = Thread.CurrentThread.CurrentCulture;
}
<h2>AgregarHorario</h2>
<table class="horario">
<colgroup>
<col id="col1">
<col id="col2">
<col id="col3">
<col id="col4">
<col id="col5">
<col id="col6">
</colgroup>
<caption>@if (ViewBag.Modulo != null)
{
<text>Modulo </text>@ViewBag.Modulo[0].NumModulo.ToString()<br />@ViewBag.Modulo[0].Nombre.ToString()<br />
}Horario del @Model.FechaInicio.Day.ToString() de @Model.FechaInicio.ToString("MMMM", culture) al @Model.FechaTermino.Day.ToString() de @Model.FechaTermino.ToString("MMMM", culture)</caption>
<thead>
<tr><th>Horario</th>
@for (int i = 0; i <= @dias; i++)
{
<th>@Model.FechaInicio.AddDays(i).ToString("dddd", culture) @Model.FechaInicio.AddDays(i).Day.ToString()</th>
}
</tr>
</thead>
<tbody>
@for (int i = 0; i <= @numhoras; i++)
{
var newTime = @Model.HorarioInicio.Add(new TimeSpan(i, 0, 0));
<tr><td>@newTime.Hours:00</td>@for (int j = 0; j <= @dias; j++)
{
<td id="@newTime.Hours" rel="@Model.FechaInicio.AddDays(j).Day.ToString()"><span class="addHorario">AgregarHorario</span></td>
}
</tr>
}
</tbody>
</thead>
</table>
@section scripts {
<script type="text/javascript">
$('span.addHorario').click(function () {
var td = $(this).parent('td');
td.load("/Cursos/CreateMateria/" + new Date(@Model.FechaInicio.Year.ToString(), @Model.FechaInicio.Month.ToString(), td.attr('rel')).toISOString().substring(0,10) + '/' + td.attr('id'));
});
$('button[id^="save"]').click(function () {
horaini = $('#horarioInicio'+$(this).attr('id').substring(4, $(this).attr('id').length)).val();
horafin = $('#horarioFin'+$(this).attr('id').substring(4, $(this).attr('id').length)).val();
alert(parseInt(horafin)-parseInt(horaini));
});
</script>
}
Но окончательный javascript, начинающийся со строки: $('button[id^="save"]').click
, не работает, я думаю, потому что дом уже построен, а jquery ничего не распознает. Может ли кто-нибудь предложить решение?
$(document).on('click', '#someElement', function() { // do something });
В идеале заменитеdocument
ближайшим предком, который существует на момент первого рендеринга представления, а#someElement
в вашем случае может быть.someClassName
(а не'button[id^="save"]'
) - person   schedule 02.03.2015