Condividi tramite


Ricaricamento rapido XAML per .NET MAUI

.NET Multipiattaforma INTERFACCIA utente (.NET MAUI) XAML Ricaricamento rapido è una funzionalità di Visual Studio che consente di visualizzare il risultato delle modifiche XAML nell'app in esecuzione, senza dover ricompilare il progetto. Senza xaml Ricaricamento rapido, devi compilare e distribuire la tua app ogni volta che vuoi visualizzare il risultato di una modifica XAML.

Quando l'app .NET MAUI è in esecuzione nella configurazione di debug, con il debugger collegato, XAML Ricaricamento rapido analizza le modifiche XAML e invia tali modifiche all'app in esecuzione. Mantiene lo stato dell'interfaccia utente, poiché non ricrea l'interfaccia utente per la pagina completa e aggiorna le proprietà modificate nei controlli interessati dalle modifiche. Inoltre, lo stato di navigazione e i dati verranno mantenuti, consentendo di eseguire rapidamente l'iterazione nell'interfaccia utente senza perdere la posizione nell'app. Di conseguenza, si passerà meno tempo alla ricompilazione e alla distribuzione delle app per convalidare le modifiche dell'interfaccia utente.

Per impostazione predefinita, non è necessario salvare il file XAML per visualizzare i risultati delle modifiche. Gli aggiornamenti vengono invece applicati immediatamente durante la digitazione. Tuttavia, in Windows è possibile modificare questo comportamento in modo da aggiornare solo al salvataggio del file. A tale scopo, selezionare la casella di controllo Applica Ricaricamento rapido XAML al salvataggio del documento nelle impostazioni dell'IDE Ricaricamento rapido disponibili selezionando Opzioni di debug >> XAML Ricaricamento rapido dalla barra dei menu di Visual Studio. L'aggiornamento al salvataggio del file può essere utile solo se si apportano aggiornamenti XAML più grandi e non si desidera che vengano visualizzati fino al completamento.

Nota

Se stai scrivendo un'app UWP o WPF nativa, senza usare .NET MAUI, vedi Che cos'è xaml Ricaricamento rapido per le app WPF e UWP?.

Xaml Ricaricamento rapido è disponibile sia in Visual Studio 2022 che in Visual Studio 2022 per Mac. In Windows il Ricaricamento rapido XAML è disponibile in Android, iOS e WinUI su emulatori, simulatori e dispositivi fisici. In Mac, xaml Ricaricamento rapido è disponibile in Android, iOS e Mac Catalyst su emulatori, simulatori e dispositivi fisici. In tutti i casi, xaml Ricaricamento rapido richiede che la configurazione di debug sia denominata Debug.

Importante

I Ricaricamento rapido XAML non ricaricano il codice C#, inclusi i gestori eventi.

Abilitare Ricaricamento rapido XAML

Xaml Ricaricamento rapido è abilitato per impostazione predefinita in Visual Studio 2022. Se è stato disabilitato in precedenza, può essere abilitato selezionando Opzioni > di debug > XAML Ricaricamento rapido dalla barra dei menu di Visual Studio. Nella finestra di dialogo Opzioni verificare quindi che le opzioni Abilita Ricaricamento rapido XAML, WinUI (incluso .NET MAUI) e Android e iOS (.NET MAUI) siano selezionate:

Opzioni di Ricaricamento rapido XAML per .NET MAUI in Visual Studio.

Quindi, in iOS nelle impostazioni di compilazione verificare che il linker sia impostato su "Don't Link".

Ricaricamento su più piattaforme

XAML Ricaricamento rapido supporta il debug simultaneo di più piattaforme in Visual Studio e Visual Studio per Mac, purché siano presenti progetti head separati per ogni piattaforma anziché una singola app di progetto. Ad esempio, è possibile distribuire un'istanza di Android e una destinazione iOS contemporaneamente per visualizzare le modifiche riflesse in entrambe le piattaforme contemporaneamente. Per eseguire il debug su più piattaforme in Windows, vedere Procedura: Impostare più progetti di avvio. Per eseguire il debug su più piattaforme in un Mac, vedere Impostare più progetti di avvio.

Risoluzione dei problemi

L'output Ricaricamento rapido XAML visualizza i messaggi di stato che possono essere utili per la risoluzione dei problemi. In Visual Studio questi elementi possono essere visualizzati selezionando Visualizza output dalla barra dei menu e quindi selezionando Xamarin Ricaricamento rapido nell'elenco a discesa Mostra output da: .> In Visual Studio per Mac, questi possono essere visualizzati passando il cursore del mouse sul Ricaricamento rapido XAML nella barra di stato.

Se l'Ricaricamento rapido XAML non riesce a inizializzare, è necessario assicurarsi di usare la versione più recente di .NET MAUI, la versione più recente dell'IDE e che le impostazioni del linker iOS siano impostate su Non collegare nelle impostazioni di compilazione del progetto.

Xaml Ricaricamento rapido richiede che la configurazione di debug sia denominata Debug. Se viene usata una configurazione di compilazione personalizzata, xaml Ricaricamento rapido smetterà di funzionare se la configurazione della compilazione non è denominata Debug.

Se non accade nulla quando si salva il file XAML, assicurarsi che il Ricaricamento rapido XAML sia abilitato nell'IDE. Per altre informazioni, vedere Abilitare Ricaricamento rapido XAML.

Se si apporta una modifica che il parser Ricaricamento rapido XAML vede come non valido, viene visualizzato l'errore sottolineato nell'editor e lo include nella finestra Elenco errori. Ricaricamento rapido gli errori hanno un codice di errore che inizia con "XHR" (per Ricaricamento rapido XAML). Se sono presenti errori di questo tipo nella pagina, xaml Ricaricamento rapido non applicherà modifiche all'app in esecuzione fino a quando gli errori non sono stati corretti.

Non è possibile aggiungere, rimuovere o rinominare file o pacchetti NuGet durante una sessione di Ricaricamento rapido XAML. Se aggiungi o rimuovi un file o un pacchetto NuGet, ricompila e ridistribuisci l'app per continuare a usare Ricaricamento rapido XAML.

La disabilitazione della compilazione XAML con [XamlCompilation(XamlCompilationOptions.Skip)] non è supportata e può causare problemi con l'albero visuale attivo. Per altre informazioni sulla struttura ad albero visuale attiva, vedere Esaminare la struttura ad albero visuale di un'app MAUI .NET.