Поскольку DetectIE()
- это функция JS, вы не можете использовать ее для сравнения с блоком Razor @if
. Вы должны поместить его внутрь <script>
с помощью jQuery.append()
, чтобы добавить соответствующий тег в целевой элемент:
<script>
$(function() {
// other stuff
if (DetectIE())
{
$('#targetElement').append("<embed data-bind=\"attr: { src: data.files()[currentPage()] + '#toolbar=0&navpanes=0&scrollbar=0' }\" type=\"application/pdf\" style=\"width: 100%; height: 800px !important;\">");
}
else
{
$('#targetElement').append("<object data-bind=\"attr: { data: data.files()[currentPage()] + '#toolbar=0&navpanes=0&scrollbar=0' }\" type=\"application/pdf\" width=\"100%\" height=\"600px\"></object>");
}
});
</script>
Пример целевого элемента:
<div id="targetElement" class="primary-content"></div>
Если вы хотите проверить любую версию IE со стороны контроллера, вы можете использовать это:
bool isIE = (Request.Browser.Browser == "IE" || Request.Browser.Browser == "InternetExplorer");
А затем передать значение ViewBag
:
ViewBag.IsIE = isIE;
Пример использования JS
if (@ViewBag.IsIE)
{
// render embed tag
}
else
{
// render object tag
}