Nessun risultato. Prova con un altro termine.
Guide
Notizie
Software
Tutorial

Impostare il 'focus' nei controlli

Primo esempio per lavorare con i nuovi controlli di ASP.NET 2.0
Primo esempio per lavorare con i nuovi controlli di ASP.NET 2.0
Link copiato negli appunti

Iniziamo ad esaminare le novità introdotte sui controlli con un semplice esempio. Vogliamo realizzare una pagina in cui l'utente possa inserire lo stato civile e l'età. Se l'utente seleziona "Sposato", il cursore si posiziona su una casella di testo in cui scrivere il nome del coniuge. Se, invece, l'utente seleziona "Single", il cursore salta direttamente alla casella per l'inserimento dell'età.

Proviamo a realizzare questa pagina con il VWD. Creiamo un nuovo sito sul "File System" e chiamiamolo "Lezione7", scegliamo il linguaggio C# e otteniamo la Default.aspx

In modalità Progettazione (Design view) scriviamo "Stato sociale:", andiamo a capo e trasciniamo dalla Standard Toolbox un RadioButtonList sulla nostra pagina. Clicchiamo con il destro sulla freccia che appare passando sul componente.

Figura 1. Modificare le proprietà del componente
Modificare le proprietà del componente

Appare un menu dal quale scegliamo "Modifica elementi" (Edit Items). Qui possiamo aggiungere alcuni membri (members) alla collezione. Per esempio inseriamo "Celibe/Nubile" e "Sposato/Sposata".

Figura 2. Aggiungere membri alla collezione
Aggiungere membri alla collezione

Impostiamo la proprietà AutoPostBack=true spuntando "Attiva AutoPostBack" (Enable AutoPostBack). Questa scelta permette di causare il PostBack senza necessità di un bottone di "submit". La selezione di una delle opzioni della lista provocherà il refresh della pagina.

Il metodo Focus()

Abbiamo detto che a seconda dello stato civile scelto il cursore dovrebbe andare su caselle di testo differenti. Nella precedente versione di ASP.NET, per "mettere a fuoco" un controllo bisognava scrivere del codice client-side (ad esempio JavaScript). In ASP.NET 2.0, questo processo è stato semplificato e lo si può fare utilizzando il metodo Focus().

Aggiungiamo quindi le due TextBox: una con id="TextBox1" ed etichetta "Nome del Consorte", l'altra con id="TextBox2" ed etichetta "Età".

Con un doppio click su un controllo, VWD ci permette di scrivere del codice (in modalità origine) per gestire l'evento principale del controllo stesso. Clicchiamo quindi due volte sulla RadioButtonList per implementare le nostre regole sul focus nella pagina del codice.

Si apre la pagina del codice con il cursore impostato all'interno del gestore di evento da implementare: RadioButtonList1_SelectedIndexChanged. Qui inseriamo il nostro codice:

Listato 7. Gestore dell'evento

protected void RadioButtonList1_SelectedIndexChanged(object sender, EventArgs e)
{
  // controlliamo il valore selezionato
  if (RadioButtonList1.SelectedValue == "Celibe/Nubile")
    // si passa alla textbox dell'età
    TextBox2.Focus();
  else
    // altrimenti al nome del consorte
    TextBox1.Focus();
}

Salviamo i due file e testiamo l'applicazione premendo F5.

Figura 3. Aspetto dell'applicazione finita
Aspetto dell'applicazione finita

Possiamo verificare che se spuntiamo Celibe/Nubile, il cursore si sposta sul campo di input Età, e se spuntiamo Sposato/Sposata, il cursore si sposta sul campo di input Nome del Consorte.

Il focus in un controllo si può impostare anche utilizzando il metodo SetFocus() della classe Page. La sintassi è semplice:

Sintassi di Page.SetFocus()

Page.SetFocus(NomeControllo)

È possibile scaricare il sorgente dell'esempio qui.

Ti consigliamo anche