Diskuze: ASP.NET MVC Změna obrázku v otevřeném View
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 7 zpráv z 7.
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Už jsem na to příšel.
ve View
<img id="_Obrazek" src="@Url.Content("~/Obrazky/Web.png")" onload="ZmenObrazekZa5s()" />
<script>
function ZmenObrazekZa5s()
{
$.ajax({
url: '@Url.Action("ZmenObrazek", "Test")',
data: { },
type: "post",
success: function (newurl)
{
$('#_Obrazek').attr('src', 'Url.Content(newurl)');
},
error: function ()
{
alert('error');
}
});
}
</script>
a v Controller
[HttpPost]
public ActionResult ZmenObrazek()
{
System.Threading.Thread.Sleep(5000); //Simulace časově náročné operace
return Json("~/Obrazky/Odskrtnuto.png");
}
Neví jestli je to úplně nejlepší řešení, ale funguje to
Tak ještě oprava
ve View
<img id="_Obrazek" src="@Url.Content("~/Obrazky/Web.png")" onload="ZmenObrazekZa5s()" />
<script>
function ZmenObrazekZa5s()
{
$.ajax({
url: '@Url.Action("ZmenObrazek", "Test")',
data: { },
type: "post",
success: function (newurl)
{
$('#_Obrazek').attr('src', newurl);
},
error: function ()
{
alert('error');
}
});
}
</script>
a v Controller
[HttpPost]
public ActionResult ZmenObrazek()
{
System.Threading.Thread.Sleep(5000); //Simulace časově náročné operace
return Json(Url.Content("~/Obrazky/Odskrtnuto.png"));
}
Bohužel jsem zjistil, že onload nefunguje při načtení stránky, ale
pouze při změně src v případě <img>
Napadá někoho jak funkci na změnu obrázku spustit při otevření
stránky?
Ahoj, zkus toto.
<img id="_Obrazek" src="@Url.Content("~/Obrazky/Web.png")" />
<script>
$(document).ready(
function(){
$.ajax({
url: '@Url.Action("ZmenObrazek", "Test")',
data: { },
type: "post", //endpoint by mohl být typu GET pokud tam neposíláš data. Pokud se tak rozhodneš, tak změnit i endpoint na serveru na GET
success: function (newurl)
{
$('#_Obrazek').attr('src', newurl);
},
error: function ()
{
alert('error');
}
});
})
</script>
Tohle je to co potřebuji, bohužel to funguje pouze pokud ten script
vložím do _Layout.cshtml.
Já bych to potřeboval spustit až při otevření konkrétního View.
Zjistil jsem, že to jde vyřešit takto, ale trošku se bojím zahlcení a nepřehlednosti v případě, že tam takových scriptů bude více.
@if (@ViewData["Title"] == "Test")
{
<script>
$(document).ready(
function(){
$.ajax({
url: '@Url.Action("ZmenObrazek", "Test")',
data: { },
type: "post", //endpoint by mohl být typu GET pokud tam neposíláš data. Pokud se tak rozhodneš, tak změnit i endpoint na serveru na GET
success: function (newurl)
{
$('#_Obrazek').attr('src', newurl);
},
error: function ()
{
alert('error');
}
});
})
</script>
}
Proc testujes nazev teho vievu cez ViewData[Title]???? Vloz ten script rovno do Viewu a on sa nacita do Layoutu az sa ten VIew zobrazy....
@RenderSection("Scripts", required: false) // toto je v _Layout.cshtml
// toto je v ten Viewu
@section Scripts{
<script>
// tvuj script
</script>
}
Super, teď už to funguje přesně tak jak potřebuju.
Díky za pomoc
Zobrazeno 7 zpráv z 7.