Un web service REST esposto tramite WCF può essere facilmente invocato da codice Javascript; utilizzando jQuery, in particolare, è possibile ottenere risultati avanzati in maniera molto semplice. Il metodo da utilizzare è $.ajax al quale dobbiamo specificare la modalità della richiesta (POST), l'url del webservice e il nome del metodo (nel formato "urlBase/nomeMetodo"), eventuali parametri di input e una funzione di callback da eseguire al termine dell'operazione.
Un caso in cui questa funzionalità torna utile è quando si vuole caricare dinamicamente il contenuto di una popup: possiamo infatti invocare il metodo del web service tramite jQuery e sfruttare la Dialog di jQuery UI per visualizzarli.
Il primo passo consiste nel creare il codice HTML con il pulsante che mostra il popup ed il div che conterrà il testo che apparira in questo.
<input type="button" value="ShowModal" id="btnShowModal" /> <div id="dialog"></div>
Successivamente, al load della pagina, associamo un evento al click del bottone e configuriamo il div come una popup:
$(function() { $("#btnShowModal").click(ShowModal) $("#dialog").dialog({ modal: true, autoOpen: false, title: "titolo", width: 400, height:200 }); });
Infine, nel metodo ShowModal scatenato al click del bottone, si mostra la dialog e si effettua la chiamata ajax al successo della quale si popola il popup con i dati del server.
function ShowModal(ev) { $("#dialog").dialog('open'); $.ajax({ type: "POST", url: "http://localhost:3612/test/Service.svc/DoWork", data: "{}", contentType: "application/json; charset=utf-8", dataType: "json", success: function(data) { $("#dialog").html(data.d); } }); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
I più letti di oggi
- Simulare Azure Cosmos DB in locale con Docker
- Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- .NET Conference Italia 2024 - Milano
- .NET Conference Italia 2023 - Milano e Online