Nella versione 102 di Chrome, troviamo nuove specifiche per l'interazione delle PWA con il file system, rendendo un'applicazione web sempre più simile a una nativa. Tali modifiche sono già disponibili anche su altri browser.
Per arrivare a ciò, non dovremmo agire solo sul codice, ma modificare anche il manifest.json, il file che verrà letto dal dispositivo per consentire l'intallazione come PWA. Al suo interno avremo bisogno di aggiungere la proprietà "file_handlers" come mostrato nell'esempio.
{ [...], "file_handlers": [ { "action": "/open-csv", "accept": { "text/csv": [".csv"] }, "icons": [ { "src": "csv-icon.png", "sizes": "256x256", "type": "image/png" } ], "launch_type": "single-client" }, { "action": "/open-svg", "accept": { "image/svg+xml": ".svg" }, "icons": [ { "src": "svg-icon.png", "sizes": "256x256", "type": "image/png" } ], "launch_type": "multiple-client" } ] }
Tramite l'array di oggetti abbiamo specificato la possibilità di aprire sia file csv, in modalità singola, che svg, con la possibilità di selezionare più file.
Per concludere dovremmo scrivere il codice JavaScript per aprire la finestra di selezione adeguata per tali file. Anche in questo caso possiamo usare tutto quello che il sistema ci fornisce gratuitamente, scrivendo poche semplici righe di codice.
// verifico l'esistenza della funzionalità if ('launchQueue' in window && 'files' in LaunchParams.prototype) { // imposto il gestore del selettore del file launchQueue.setConsumer((launchParams) => { // Verifico che vi sia almeno un file if (!launchParams.files.length) { return; } for (const fileHandle of launchParams.files) { // Gestione del file } }); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Supportare la sessione affinity di Azure App Service con Application Gateway
Utilizzare Locust con Azure Load Testing
Potenziare la ricerca su Cosmos DB con Full Text Search
Eliminare record doppi in Sql Server
Documentare i servizi REST con Swagger e OpenAPI con .NET 9
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Introduzione alle Container Queries
Gestire il routing HTTP in Azure Container App
Utilizzare Container Queries nominali
Integrare SQL Server in un progetto .NET Aspire
Configurare e gestire sidecar container in Azure App Service
Evitare memory leaks nelle closure JavaScript
I più letti di oggi
- .NET Conference Italia 2025 - Milano
- Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
- The Agentic Day - Milano
- Gestione ciclo di vita in .NET Aspire
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Gestione CSS in Blazor con .NET 9
- Gestione file Javascript in Blazor con .NET 9
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!