На одной из моих страниц просмотра у меня есть asp.net mvc PartialView. PartialView содержит несколько javascript (и jquery). В моем главном представлении asp.net я загружаю PartialView с помощью ajax в теге div, как показано ниже. То есть, из контроллера я возвращаю PartialView ( "_ DonorEdit" ), и на моей главной странице я использую javascript для замены содержимого тега div на ответ PartialView.
<div class="content" id="content">
@{Html.RenderPartial("_DonorEdit");}
</div>
Все работает отлично, за исключением javascript, содержащегося в partialView (_DonorEdit). Таким образом, вопрос сводится к тому, что у меня есть javascript, встроенный в тег div и до сих пор работающий правильно.
Эта проблема возникает только тогда, когда частичный вид возвращается из вызова ajax. В приведенном выше коде, если я непосредственно включаю PartialView (по запросу без аякса), тогда javascript работает правильно. Но если я позже заменил содержимое div, используя запрос ajax, javascript, включенный в PartialView, не работает. Встроенный javascript просто не появляется вместе с Partial View. Так что, по-видимому, есть и другая причина, почему javascript, встроенный в Partial View, не попадает в браузер после успеха запроса ajax.
Часть моего кода javascript
<script type=...>
//Date Picker. This works. I get Calendar popup as expected
$(document).ready(function () {
$("#Donor_BirthDate").datepicker({
dateFormat: "dd-mm-yy",
changeMonth: true,
changeYear: true,
yearRange: "-75:+0"
});
$("#Donor_DateLastDonated").datepicker({
dateFormat: "dd-mm-yy",
changeMonth: true,
changeYear: true,
yearRange: "-20:+1"
});
});
//Dropdown handler. Does not make it in my final View.
function residenceStateChanged(e) {
var url = '@Url.Action("_GetCities", "DropDown")';
var cmbResidenceCityId = $('#ResidenceCityId').data('tDropDownList');
cmbResidenceCityId.loader.showBusy();
$.ajax({
type: 'GET',
url: url,
data: { StateId: e.value, AddSelectOption: true, SelectOption: 'Select' },
traditional: true,
success: function (resp, textStatus, jqXHR) {
cmbResidenceCityId.dataBind(resp);
cmbResidenceCityId.select(0);
cmbResidenceCityId.trigger.change();
},
error: function (jqXHR, textStatus, errorThrown) {
alert(jqXHR.responseText);
},
complete: function () {
cmbResidenceCityId.loader.hideBusy();
}
});
}
....//Some other code omitted. Does not make it in final view.
</script>