React può essere utilizzato come base nello sviluppo di applicazioni a pagina singola ma è utilizzabile anche su mobile tramite React Native, una libreria sempre sviluppata da Meta che tramuta i componenti React in componenti nativi (iOS e Android)[5]. Tuttavia, React si occupa solo del rendering dei dati sul DOM, pertanto la creazione di applicazioni React richiede generalmente l'uso di librerie aggiuntive per lo state management e il routing.[6] Redux[7] e React Router[8] sono i rispettivi esempi[9] di tali librerie. A questo fine è possibile utilizzare anche dei framework terzi, come ad esempio Next.js.[10]
Utilizzo di base
Di seguito è riportato un esempio rudimentale di utilizzo di React in HTML con JSX e JavaScript.
<!DOCTYPE html><htmllang="en"><head><metacharset="utf-8"/><title>React App</title></head><body><noscript>You need to enable JavaScript to run this app.</noscript></body></html>
La funzione Saluto è un componente React che mostra il famoso "Hello, world" introduttivo.
Caratteristiche degne di nota
Componenti
Il codice di React è costituito da entità denominate componenti. I componenti possono essere sottoposti a rendering su un particolare elemento nel DOM usando la libreria React DOM. Quando si esegue il rendering di un componente, si possono passare valori noti come "props"[11]:
I componenti basati su classi vengono dichiarati utilizzando le classi ES6. Sono anche noti come componenti "stateful", perché il loro stato può contenere valori in tutto il componente e può essere passato ai componenti figlio tramite props:
Un'altra caratteristica notevole è l'uso di un Document Object Model (DOM) virtuale. React crea una cache della struttura dati in-memory, calcola le differenze risultanti e quindi aggiorna in modo efficiente il DOM visualizzato dal browser.[12] Ciò consente al programmatore di scrivere codice come se l'intera pagina fosse renderizzata su ogni modifica, mentre le librerie React eseguono il rendering solo dei sottocomponenti che cambiano effettivamente.
Metodi del ciclo di vita
I metodi del ciclo di vita sono hook che consentono l'esecuzione di codice in punti prestabiliti durante la vita di un componente.
shouldComponentUpdate consente allo sviluppatore di impedire il rendering non necessario di un componente restituendo false se non è richiesto un rendering.
componentDidMount viene chiamato una volta che il componente è "montato" (il componente è stato creato nell'interfaccia utente, spesso associandolo a un nodo DOM). Questo è comunemente usato per attivare il caricamento dei dati da una fonte remota tramite un'API.
componentWillUnmount viene chiamato immediatamente prima che il componente venga demolito o "smontato". Questo è comunemente usato per cancellare dipendenze che richiedono risorse al componente che non saranno semplicemente rimosse con lo smontaggio del componente (ad esempio, la rimozione di qualsiasi istanza setInterval() che è correlata al componente o un "eventListener" impostato sul "documento" a causa della presenza del componente).
render è il metodo di ciclo di vita più importante e l'unico richiesto in qualsiasi componente. Di solito viene chiamato ogni volta che viene aggiornato lo stato del componente, che dovrebbe riflettersi nell'interfaccia utente.
JSX
JSX, o JavaScript XML, è un'estensione della sintassi del linguaggio JavaScript.[13] Simile nell'aspetto all'HTML, JSX fornisce un modo per strutturare il rendering dei componenti usando una sintassi familiare a molti sviluppatori. I componenti di React sono in genere scritti usando JSX, sebbene non debbano esserlo (i componenti possono anche essere scritti in puro JavaScript). JSX è simile a un'altra sintassi di estensione creata da Facebook per PHP chiamata XHP.
Elementi multipli sullo stesso livello devono essere racchiusi in un singolo elemento contenitore come l'elemento <div> mostrato sopra o restituiti come matrice.[14]
Attributi
JSX offre una gamma di attributi di elemento progettati per rispecchiare quelli forniti da HTML. Possono essere passati al componente anche attributi personalizzati.[15] Tutti gli attributi verranno ricevuti dal componente come props.
Espressioni JavaScript
Le espressioni JavaScript (ma non le istruzioni) possono essere utilizzate all'interno di JSX con parentesi graffe {}:
<h1>{10+1}</h1>
L'esempio sopra verrà così visualizzato:
<h1>11</h1>
Dichiarazioni condizionali
Le istruzioni if-else non possono essere utilizzate all'interno di JSX ma è possibile utilizzare espressioni condizionali. L'esempio seguente mostrerà {i===1?'true':'false'} come stringa 'true' perché i è uguale a 1.
Le funzioni e JSX possono essere utilizzate nei condizionali:
classAppextendsReact.Component{render(){constsections=[1,2,3];return(<div>{sections.length>0&§ions.map(n=>(/* 'key' is used by react to keep track of list items and their changes *//* Each 'key' must be unique */<divkey={"section-"+n}>Section{n}</div>))}</div>);}}
Il codice scritto in JSX richiede la conversione con uno strumento come <i>Babel</i> prima di poter essere compreso dai browser web.[16] Questa elaborazione viene generalmente effettuata nel corso del processo di costruzione del software, prima che l'applicazione venga distribuita.
Architettura oltre HTML
L'architettura di base di React si applica oltre al rendering HTML nel browser. Ad esempio, Facebook ha grafici dinamici che eseguono il rendering in tag <canvas>[17] e Netflix e PayPal utilizzano il caricamento universale per eseguire il rendering di HTML identico sia sul server che sul client.[18][19]
Hooks di React
Gli hooks, introdotti dalla versione 16.8 (Febbraio 2019), sono funzioni che consentono agli sviluppatori di "agganciarsi" allo stato di React e alle caratteristiche del ciclo di vita dei componenti delle funzioni.[20] Rendono i codici leggibili e facilmente comprensibili. Gli hooks non funzionano all'interno delle classi: permettono infatti di utilizzare React senza classi.[21]
React fornisce alcuni hook incorporati come useState,[22]useContext, useReducer e useEffect[23] per citarne alcuni. Sono tutti indicati nella guida alle API di riferimento degli Hooks.[24]useState e useEffect, che sono i più utilizzati, sono utili al controllo rispettivamente degli stati e degli effetti collaterali nei componenti React.
Esempio di utilizzo di useState in un componente funzionale.
Ci sono anche regole degli hooks[25] che devono essere seguite prima che gli stessi possano essere utilizzati:
Gli hooks devono essere chiamati solo al livello più alto (non all'interno di loop o istruzioni if).
Gli hooks devono essere chiamati solo dai componenti di funzione React, non dalle normali funzioni o dai componenti della classe.
Hooks personalizzati
La creazione di hooks personalizzati[26] consente di estrarre la logica dei componenti in funzioni riutilizzabili. Un hook personalizzato è una funzione JavaScript il cui nome inizia con "use" e che può chiamare altri hooks. Le regole generali degli hooks si applicano anche a quelli personalizzati.
Idiomi comuni
React non intende fornire una "libreria di applicazione" completa. È progettato specificamente per la creazione di interfacce utente[1] e pertanto non include molti degli strumenti che alcuni sviluppatori potrebbero ritenere necessari per creare un'applicazione. Ciò consente di scegliere le librerie che lo sviluppatore preferisce per eseguire attività quali l'accesso alla rete o l'archiviazione locale dei dati. Modelli comuni di utilizzo sono emersi man mano che la libreria è maturata.
Uso dell'architettura Flux
Per supportare il concetto di flusso di dati unidirezionale di React (che va in contrasto con il flusso bidirezionale di AngularJS), l'architettura Flux rappresenta un'alternativa alla popolare architettura modello-view-controller. Flux include le azioni che vengono inviate tramite un dispatcher centrale a uno store e le modifiche a quest'ultimo vengono propagate alla vista.[27] Se utilizzata con React, questa propagazione viene eseguita attraverso le proprietà del componente.
Un componente React sotto l'architettura Flux non dovrebbe modificare direttamente alcun oggetto prop, ma dovrebbe essere passato alle funzioni di callback che creano azioni inviate dal dispatcher per modificare lo store. L'azione è un oggetto la cui responsabilità è descrivere ciò che è accaduto: ad esempio, un'azione che descrive un utente che "segue" un altro potrebbe contenere un ID utente, un ID utente di destinazione e il tipo USER_FOLLOWED_ANOTHER_USER.[29] Gli store, che possono essere pensati come modelli, possono modificarsi in risposta alle azioni ricevute dal dispatcher.
Questo modello viene talvolta espresso come "properties flow down, actions flow up". Molte implementazioni di Flux sono state create sin dalla sua nascita, delle quali forse la più nota è Redux, che dispone di un singolo store, spesso chiamato una single source of truth (SSOT).[30]
Sviluppo futuro
Lo stato del progetto può essere monitorato tramite il forum di discussione del core team.[31] Tuttavia, le principali modifiche a React passano attraverso i repository issues e le richieste di pull di Future of React.[32][33] Ciò consente alla comunità di React di fornire feedback sulle nuove potenziali funzionalità, sulle API sperimentali e sui miglioramenti della sintassi JavaScript.
Storia
React è stato creato da Jordan Walke, un ingegnere software di Facebook, che lo ha chiamato inizialmente "FaxJS".[34] È stato influenzato da XHP, una libreria di componenti HTML per PHP . È stato utilizzato inizialmente sul News Feed di Facebook nel 2011 e successivamente su Instagram nel 2012.[35] È stato rilasciato al pubblico al JSConf US del maggio 2013.[36]
React Native, che consente lo sviluppo nativo di Android, iOS e UWP con React, è stato annunciato al React Conf di Facebook a febbraio 2015 e rilasciato a marzo 2015.
Il 18 aprile 2017, Facebook ha annunciato React Fiber, un nuovo algoritmo di base della libreria React per la creazione di interfacce utente.[37] React Fiber è stato pensato come fondamento per eventuali miglioramenti e sviluppi futuri della libreria React.[38]
Il 26 settembre 2017, è stato rilasciato al pubblico React 16.0.[39]
Il 16 febbraio 2019, è stato rilasciato al pubblico React 16.8.[40] Il rilascio ha introdotto gli hooks.[41]
Versioni
Versione
Data di pubblicazione
Cambiamenti
0.3.0
29 maggio 2013
Versione pubblica iniziale
0.4.0
20 luglio 2013
Supporto ai nodi di commento <div>{/* */}</div>, API di rendering lato server migliorate, rimosso React.autoBind, supporto per il prop key, miglioramenti ai moduli, bug corretti.
0.5.0
20 ottobre 2013
Migliorato l'utilizzo della memoria, supporto agli eventi di selezione e composizione, supporto a getInitialState e getDefaultProps nei mixin, aggiunti React.version e React.isValidClass, migliorata compatibilità per Windows.
0.8.0
20 dicembre 2013
Aggiunto supporto a righe e colonne, defer e async, loop per <audio> e <video>, attributi di autoCorrect. Aggiunti eventi onContextMenu, aggiornati jstransform, esprima-fb e browserify.
0.9.0
20 febbraio 2014
Aggiunto supporto a crossOrigin, download e hrefLang, mediaGroup e muted, sandbox, seamless e srcDoc, attributi scope. Aggiunti any, arrayOf, component, oneOfType, renderable, shape to React.PropTypes, Aggiunto supporto agli eventi onMouseOver e onMouseOut, Aggiunto supporto ad onLoad e onError sugli elementi <img>.
0.10.0
21 marzo 2014
Aggiunto supporto agli attributi srcSet e textAnchor, aggiunta della funzione di aggiornamento per dati immutabili, verifica dell'esclusione del tag di chiusura da tutti gli elementi void.
0.11.0
17 luglio 2014
Supporto SVG migliorato, evento e.view normalizzato, aggiornamento comando $apply, aggiunto supporto ai namespaces, aggiunta nuova API transformWithDetails, include pacchetti pre-compilati sotto dist/, MyComponent() ora restituisce un descrittore, anziché un'istanza.
0.12.0
21 novembre 2014
Aggiunte nuove funzionalità: Spread operator ({...}) introdotto per deprecare this.transferPropsTo. Aggiunto supporto per acceptCharset, classID, attributi HTML manifest, React.addons.batchedUpdate aggiunto all'API, @jsx React.DOM non più necessario. Risolti problemi con transizioni CSS.
0.13.0
10 marzo 2015
Deprecati pattern segnalati nella 0.12 come non più funzionanti, l'ordine di risoluzione dei ref è cambiato. Rimosse proprietà this._pendingState e this._rootNodeID. Supporto classi ES6, aggiunta API React.findDOMNode (componente), supporto a iteratori e sequenze immutable-js, aggiunta nuova funzionalità React.addons.createFragment, deprecata React.addons.classSet.
0.14.1
29 ottobre 2015
Aggiunto supporto a srcLang, default, attributi di tipo e attributo color, garantito accesso .props legacy su nodi DOM, corretto ScryRenderedDOMComponentsWithClass, aggiunto react-dom.js.
15.0.0
7 aprile 2016
Il rendering iniziale ora utilizza document.createElement invece di generare HTML, Niente più <span> extra, supporto SVG migliorato, ReactPerf.getLastMeasurements () è opaco, nuove deprecazioni introdotte con un avviso, risolte diversi piccoli leak di memoria, React DOM ora supporta gli attributi HTML cite e profile e le proprietà CSS cssFloat, gridRow e gridColumn.
15.1.0
20 maggio 2016
Correzione di un bug di batch, offerto l'accesso all'ultima assegnazione di oggetti, corretta regressione, rimosso utilizzo dell'utilità di merge, rinominati alcuni moduli.
Inclusione informazioni sullo stack dei componenti, rimossa la convalida dei props al momento del montaggio, aggiunti React.PropTypes.symbol, gestione onLoad a <link>, gestione onError all'elemento <source>, API isRunning(), corretta regressione sulle prestazioni.
15.3.0
30 luglio 2016
Aggiunto React.PureComponent, risolto problema con il rendering del server nidificato, aggiunui xmlns, xmlnsXlink a supporto degli attributi SVG e referrerPolicy agli attributi HTML, aggiornato componente aggiuntivo React Perf, risolto problema con ref.
15.3.1
19 agosto 2016
Migliorate prestazioni dei build di sviluppo, pulizia hooks interni, aggiornata fbjs, migliorati tempi di avvio di React, corretta perdita di memoria nel rendering del server, corretto React Test Renderer, trackedTouchCount invariante su console.error.
15.4.0
16 novembre 2016
Il pacchetto React e la build del browser non includono più React DOM, prestazioni di sviluppo migliorate, errori di test occasionali corretti, aggiornamento dell'API di batchUpdates, React Perf e ReactTestRenderer.create().
15.4.1
23 novembre 2016
Ristrutturata l'assegnazione delle variabili, corretta gestione degli eventi, corretta compatibilità della build del browser in ambienti AMD.
15.4.2
6 gennaio 2017
Risolti problemi di build, aggiunte dipendenze di pacchetto mancanti, messaggi di errore migliorati.
15.5.0
7 aprile 2017
Aggiunto react-dom/test-utils, rimosse peerDependencies, risolto problema con il Closure Compiler, aggiunto avviso di deprecazione per React.createClass e React.PropTypes, corretto bug su Chrome.
15.5.4
11 aprile 2017
Corretta compatibilità con Enzyme esponendo batchedUpdates su renderer superficiali, aggiornata versione prop-types, corretto pacchetto react-addons-create-fragment per includere la trasformazione loose-envify.
15.6.0
13 giugno 2017
Aggiunto supporto alle variabili CSS nell'attributo di stile e nelle proprietà di stile della Grid, corretto supporto AMD per i componenti aggiuntivi in base a react, rimossa dipendenza non necessaria, aggiunto avviso di deprecazione per gli helper di factory React.createClass e React.DOM.
16.0.0
26 settembre 2017
Gestione degli errori migliorata con l'introduzione dei "error boundaries", consentito passaggio a React DOM di attributi non standard, modifiche minori al comportamento di setState, rimozione di react-con-addons.js, aggiunta di React.createClass come create-react-class, React.PropTypes come prop-types, React.DOM come react-dom-factories, modifiche al comportamento dei metodi di pianificazione e ciclo di vita.
16.1.0
9 novembre 2017
Interruzione dei release di Bower, correzione di una variabile globale extra accidentale nelle build UMD, correzione dell'attivazione di onMouseEnter e onMouseLeave, correzione del plceholder di <textarea>, rimozione del codice inutilizzato, aggiunta di una dipendenza mancante di package.json, aggiunta del supporto a React DevTools.
16.3.0
29 marzo 2018
Aggiunta una nuova API di contesto ufficialmente supportata, aggiunto nuovo pacchetto, corretto ciclo infinito quando nell'esecuzione del rendering di portali con SSR, risolto problema con this.state, risolto problema su IE/Edge.
16.3.1
3 aprile 2018
Prefisso API privata, corretta regressione delle prestazioni e gestione degli errori in modalità di sviluppo, aggiunta dipendenza peer, correzione di un falso avviso positivo su IE11 nell'utilizzo di Fragment.
16.3.2
16 aprile 2018
Risolto arresto anomalo di IE, corrette etichette nelle misurazioni dello User Timing, aggiunta build UMD, migliorate prestazioni dell'API unstable_observedBits con l'annidamento.
16.4.0
24 maggio 2018
Aggiunto supporto alla specifica Pointer Events, aggiunta possibilità di specificare propTypes, correzione contesto di lettura, corretto supporto a getDerivedStateFromProps(), risolto crash testInstance.parent, aggiunto componente React.unstable_Profiler per misurare le prestazioni, cambiati nomi degli eventi interni.
16.5.0
5 settembre 2018
Aggiunto supporto a React DevTools Profiler, gestione discreta errori in diversi casi limite, aggiunto react-dom/profiling, aggiungi evento AuxClick per browser, aggiunti campi movimentoX e movimentoY agli eventi del mouse, aggiunti tangentalPressure e campi di rotazione all'evento puntatore.
16.6.0
23 ottobre 2018
Aggiunto supporto a contextType, supporto a livelli di priorità, continuazioni e callback integrate, migliorato meccanismo di fallback, corretto overlay grigio su iOS Safari, aggiunto React.lazy() per i componenti di suddivisione del codice.
16.7.0
20 dicembre 2018
Corrette prestazioni di React.lazy per i componenti lazy-loaded, rimmossi campi su unmount per evitare leak di memoria, corretto bug in SSR, corretta regressione delle prestazioni.
16.8.0
6 febbraio 2019
Aggiunti hooks, aggiunti ReactTestRenderer.act() e ReactTestUtils.act() per gli aggiornamenti di batch, supporto agli elementi sincroni passati a React.lazy(), migliorata API di inizializzazione hook lazy useReducer.
16.8.6
27 marzo 2019
Corretto salvataggio non corretto in useReducer(), corretti avvisi iframe in Safari DevTools, avviso sull'impostazione di contextType a Context.Consumer anziché Context, avviso sull'impostazione di contextType a valori non validi.
16.9.0
9 agosto 2019
Aggiunta API <React.Profiler> per la raccolta programmata delle misurazioni delle prestazioni. rimosso unstable_ConcurrentMode a favore di unstable_createRoot
16.10.0
27 settembre 2019
Risolto caso limite in cui non veniva memorizzato un aggiornamento hook. correzione euristica per determinare quando fare l'hydrate, per non lanciarlo erroneamente durante un aggiornamento. Rimossi ulteriori campi fiber durante l'unmount per risparmiare memoria. Correzione bug sui campi di testo required in Firefox. Preferenza Object.is al posto di polyfill in linea, se disponibile. Correzione bug durante l'unione di Suspense e gestione degli errori.
16.10.1
28 settembre 2019
Corretta regressione nelle app Next.js consentendo a Suspense mismatch durante l'hydrate per procedura silent
16.10.2
3 ottobre 2019
Corretta regressione in react-native-web ripristinando l'ordine degli argomenti negli estrattori di plugin di eventi
16.11.0
22 ottobre 2019
Risolto lancio duplice degli handler di mouseenter all'interno dei contenitori React nidificati. Rimosse API sperimentali unstable_createRoot e unstable_createSyncRoot. (Questi sono disponibili nel canale sperimentale come createRoot e createSyncRoot.)
16.12.0
14 novembre 2019
React DOM - Risolti effetti passivi (useEffect) non attivati in app multi-root.
React Is - Corretti tipi lazy e memo considerati elementi anziché componenti
16.13.0
26 febbraio 2020
Funzionalità aggiunte in modalità React Concurrent. Corrette regressioni nella libreria principale di React e React Dom.
16.14.0
14 ottobre 2020
Aggiunto nuovo supporto per le trasformazioni JSX
17.0.0
20 ottobre 2020
Rimozione del pool di eventi, aggiornamenti all'algoritmo di riconciliazione dell'albero, migliore gestione degli errori e aumentato supporto per i portali.
17.0.1
22 ottobre 2020
Fixato crash su IE11
17.0.22
22 marzo 2021
Rimossa una dipendenza inutilizzata su SharedArrayBuffer (cross-origin-isolation warning)
18.0.0
29 marzo 2022
Introdotti 5 nuovi hook useId, useInsertionAffect, useTransition, useDeferredValue e useSyncExternalStore.
Nuove API quali createRoot che sostituisce ReactDOM.render, hydrateRoot che sostituisce ReactDOM.hydrate
Batch automatico (evita re-render indesiderati unendo tutti i setState)
18.1.0
26 aprile 2022
Risolti vari problemi su react-dom/client, componentWillUnmount e alcuni messaggi di warning
Licensing
La versione pubblica iniziale di React a maggio 2013 utilizzava la licenza Apache 2.0. Nell'ottobre 2014, React 0.12.0 l'ha sostituita con la licenza BSD a 3 clausole e ha aggiunto un file di testo PATENTS separato che dà il consenso l'utilizzo di eventuali brevetti di Facebook relativi al software:[42]
La licenza concessa nel presente documento terminerà, automaticamente e senza preavviso, per chiunque faccia qualsiasi reclamo (anche presentando qualsiasi azione legale, asserzione o altra azione) relativa a (a) violazione o induzione diretta, indiretta o contributiva a violare qualsiasi brevetto: (i) da parte di Facebook o di una delle sue consociate o affiliate, indipendentemente dal fatto che tale reclamo sia correlato o meno al Software, (ii) da qualsiasi parte se tale reclamo deriva in tutto o in parte da qualsiasi software, prodotto o servizio di Facebook o una delle sue sussidiarie o affiliate, indipendentemente dal fatto che tale rivendicazione sia correlata o meno al Software o (iii) da qualsiasi parte relativa al Software; o (b) che qualsiasi diritto in qualsiasi rivendicazione di brevetto di Facebook sia invalido o inapplicabile.
Questa clausola non convenzionale ha causato alcune controversie e dibattiti nella comunità degli utenti di React, perché potrebbe essere interpretata per consentire a Facebook di revocare la licenza in molti scenari, ad esempio se Facebook fa causa al licenziatario spingendo a intraprendere "altre azioni" pubblicando l'azione su un blog o altrove. Molti hanno espresso preoccupazione per il fatto che Facebook potrebbe sfruttare ingiustamente la clausola di risoluzione o che l'integrazione di React in un prodotto potrebbe complicare l'acquisizione futura di una società startup.[43]
Sulla base del feedback della comunità, Facebook ha aggiornato la concessione del brevetto ad aprile 2015 per renderla meno ambigua e più permissiva:[44]
La licenza concessa in seguito terminerà, automaticamente e senza preavviso, se tu (o una qualsiasi delle tue consociate, affiliate o agenti aziendali) avvii direttamente o indirettamente o prendi un interesse finanziario diretto in qualsiasi Dichiarazione di brevetto: (i) contro Facebook o qualsiasi delle sue consociate o affiliate aziendali, (ii) contro qualsiasi parte se tale Dichiarazione di brevetto deriva in tutto o in parte da qualsiasi software, tecnologia, prodotto o servizio di Facebook o di una qualsiasi delle sue consociate o affiliate aziendali, o (iii) contro qualsiasi parte relativo al software. [...] Una "Dichiarazione di brevetto" è qualsiasi azione legale o altra azione relativa a violazione o induzione diretta, indiretta o contributiva a violare qualsiasi brevetto, incluso un reclamo o una domanda riconvenzionale.[45]
La Apache Software Foundation ha ritenuto questo accordo di licenza incompatibile con le sue politiche di licenza, in quanto "trasmette il rischio per i consumatori a valle del nostro software sbilanciato a favore del licenziante, non del licenziatario, violando così la nostra politica legale di Apache di essere un donatore universale" e "non sono un sottoinsieme di quelle presenti in [Licenza Apache 2.0] e non possono essere concesse in licenza come [Licenza Apache 2.0] ".[46] Nell'agosto 2017, Facebook ha respinto le preoccupazioni a valle della Apache Foundation e si è rifiutata di riconsiderare la loro licenza.[47][48] Il mese seguente, WordPress deciso di riconfigurare fuori da React i suoi progetti Gutenberg e Calypso.[49]
Il 23 settembre 2017, Facebook ha annunciato che la settimana successiva avrebbe rivisto la licenza di Flow, Jest, React e Immutable.js con una licenza MIT standard; la compagnia dichiarò che React era "la base di un vasto ecosistema di software open source per il web" e che non volevano "frenare i progressi per ragioni non tecniche".[50]
Il 26 settembre 2017, React 16.0.0 è stato rilasciato con la licenza MIT.[51] Il passaggio alla licenza MIT è stato inoltre inserito nella linea di rilascio 15.x con React 15.6.2.[52]
Nick Clegg (vicepresidente per gli affari globali e la comunicazione) ·Lars Rasmussen (direttore di Graph Search) ·John Carmack (CTO di Oculus VR) ·Hugo Barra (vicepresidente di Oculus VR) ·Naomi Gleit (vicepresidente dei beni pubblici)
Universitas Adiwangsa JambiJenisSwastaDidirikan18 September 2017RektorSeno Aji, S.Pd., M.Eng., Prac.AlamatJl. Sersan Muslim RT 24, Thehok, Jambi Selatan, Kota JambiKampusUrbanNama julukanUNAJAMaskotSmart CampusSitus webunaja.ac.id Universitas Adiwangsa Jambi (disingkat UNAJA) adalah perguruan tinggi swasta yang berada di kota Jambi, provinsi Jambi, Indonesia. Berdiri pada 18 September 2017, dan saat ini dipimpin oleh Rektor Seno Aji, S.Pd., M.Eng., Prac. Sejarah singkat Universitas Adiwangsa ...
French politician Thierry BenoitParliamentary groupMoDem, (2007), New Centre (2007-2012), AC (2012-2017), UDI (2017 on)Deputy for Ille-et-Vilaine's 6th constituency in the National Assembly of FranceIncumbentAssumed office 2007Preceded byMarie-Thérèse Boisseau Personal detailsBorn (1966-09-13) 13 September 1966 (age 57)Fougères, Ille-et-Vilaine This biography of a living person needs additional citations for verification. Please help by adding reliable sources. Contentious materia...
Slovak singer and actor (born 1977) This biography of a living person needs additional citations for verification. Please help by adding reliable sources. Contentious material about living persons that is unsourced or poorly sourced must be removed immediately from the article and its talk page, especially if potentially libelous.Find sources: Kamil Mikulčík – news · newspapers · books · scholar · JSTOR (January 2011) (Learn how and when to remove th...
American action-comedy television series (1979–1985) For the 2005 film, see The Dukes of Hazzard (film). For the series score, see The Dukes of Hazzard (soundtrack). For the video game, see The Dukes of Hazzard (video game). This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: The Dukes of Hazzard – news · newspapers · boo...
Two campaigns against Joseon Invasion of Korea redirects here. For invasions of Korea during the Korean War, see Korean War. Japanese invasions of KoreaThe Japanese landing at BusanDateMay 23, 1592 – December 16, 1598(6 years, 6 months, 3 weeks and 2 days) (Gregorian calendar);1592 (Wanli 20, Bunroku 1), 13th day of the 4th month – 1598 (Wanli 26, Keichō 3), 19th day of the 11th month (lunar calendar)LocationKorean PeninsulaResult Joseon and Ming victory[1] Wi...
American college football season 2021 Iowa Hawkeyes footballBig Ten West Division championBig Ten Championship Game, L 3–42 vs. MichiganCitrus Bowl, L 17–20 vs. KentuckyConferenceBig Ten ConferenceDivisionWest DivisionRankingCoachesNo. 23APNo. 23Record10–4 (7–2 Big Ten)Head coachKirk Ferentz (23rd season)Offensive coordinatorBrian Ferentz (5th season)Offensive schemeMultipleDefensive coordinatorPhil Parker (10th season)Base defense4–3Home stad...
Alienoid 2Poster utamaNama lainHangul외계+인 2부 Arti harfiahAlien+Human Part 2Alih AksaraEuigye+in 2-bu SutradaraChoi Dong-hoonProduserAhn Soo-hyunDitulis olehChoi Dong-hoonPemeran Ryu Jun-yeol Kim Tae-ri Kim Woo-bin Penata musikJang Young-gyuSinematograferKim Tae-kyungPerusahaanproduksiCaper FilmDistributorCJ E&MTanggal rilis 10 Januari 2024 (2024-01-10) NegaraKorea SelatanBahasaKorea Alienoid 2 (Hangul: 외계+인 2부) adalah film laga fiksi ilmiah Korea ...
Luigi Macchi di Cellerecardinale di Santa Romana ChiesaIl cardinale Macchi, fotografato attorno al 1900 Incarichi ricoperti Prefetto del Palazzo Apostolico (1886-1889) Cardinale diacono di Santa Maria in Aquiro (1889-1896) Amministratore apostolico di Subiaco (1890-1896) Segretario dei Brevi Apostolici (1896-1907) Cardinale protodiacono (1896-1907) Cardinale diacono di Santa Maria in Via Lata (1896-1907) Nato3 marzo 1832 a Viterbo Ordinato presbitero1859 Creato cardinale11 febbrai...
British terrorist Shehzad TanweerBorn(1982-12-15)15 December 1982Bradford, West Yorkshire, EnglandDied7 July 2005(2005-07-07) (aged 22)London, EnglandCause of deathSuicide bombingAlma materLeeds Beckett University Shehzad Tanweer (15 December 1982 – 7 July 2005)[1] was a Pakistani-British Islamist and one of four Islamist terrorists who detonated explosives in three trains on the London Underground and one bus in central London during the 7 July 2005 London bombings. ...
American VJ, TV host and radio personality Matt PinfieldPinfield speaking in 2010Born (1961-05-28) May 28, 1961 (age 63)East Brunswick, New Jersey, U.S.Occupation(s)VJ, TV personality/hostYears active1984–presentWebsitemattpinfieldmusic.com Matthew Pinfield (born May 28, 1961) is an American television host, disc jockey, and music executive. He first reached national prominence as a VJ on MTV. He served two stints as the host of the alternative music program 120 Minutes, from 1995...
2013 CECAFA CupGOtv CECAFA Challenge CupTournament detailsHost countryKenyaDates27 November – 12 DecemberTeams12 (from 2 sub-confederations)Venue(s)6 (in 4 host cities)Final positionsChampions Kenya (6th title)Runners-up SudanThird place ZambiaFourth place TanzaniaTournament statisticsMatches played26Goals scored51 (1.96 per match)Top scorer(s) Salah Ibrahim (5 goals)← 2012 2015 → International football competition The 2013 CECAFA Cup (kno...
English-language daily newspaper The Japan TimesSample page 1 of The Japan TimesTypeDaily newspaperFormatBroadsheetOwner(s)News2u Holdings, Inc.PublisherTakeharu TsutsumiEditorHiroyasu MizunoStaff writersApproximately 130Founded22 March 1897; 127 years ago (22 March 1897)LanguageEnglishHeadquartersTokyo, JapanCirculation44,000ISSN0447-5763OCLC number21225620 Websitewww.japantimes.co.jp The Japan Times is Japan's largest and oldest English-language daily newspaper.[1][...
German actress and singer Barbara SukowaSukowa in 2010Born (1950-02-02) 2 February 1950 (age 74)[1]Bremen, West GermanyOccupation(s)Actress, singerYears active1971—presentSpouse(s)Hans-Michael Rehberg Robert Longo (m. 1993)PartnerDaniel OlbrychskiChildren3Websitewww.barbarasukowa.com Barbara Sukowa (German: [ˈbaʁ.ba.ʁa ˈzu.kɔ.va] ⓘ; born 2 February 1950) is a German actress of screen and stage and singer. She has received three...
Chemical compound RobalzotanClinical dataRoutes ofadministrationOralATC codenoneLegal statusLegal status In general: uncontrolled Identifiers IUPAC name (3R)-3-[di(cyclobutyl)amino]-8-fluoro-3,4-dihydro-2H-chromene-5-carboxamide CAS Number169758-66-1 YPubChem CID3055171IUPHAR/BPS72ChemSpider2316732 NUNIII18M56OGMECompTox Dashboard (EPA)DTXSID30168743 Chemical and physical dataFormulaC18H23FN2O2Molar mass318.392 g·mol−13D model (JSmol)Interactive image SMILES C1CC(C1)N(C...
55°56′05″N 3°39′09″W / 55.93464°N 3.6524°W / 55.93464; -3.6524 Church in West Lothian, United KingdomTorphichen PreceptoryTorphichen PreceptoryShow map of ScotlandTorphichen PreceptoryShow map of the United KingdomLocationTorphichen, West LothianCountryUnited KingdomDenominationCatholicArchitectureYears built1140s Torphichen Preceptory is a church in the village of Torphichen, West Lothian, Scotland. It comprises the remains of the preceptory (headquarters...
أديداس تيليستاركرة كأس العالم 1974 - أديداس تيليستارمعلومات عامةالنوع كرةالاستعمالات كأس العالم 1970 — بطولة أمم أوروبا 1968 البداية 1968؛ منذ 56 سنوات (1968)المصنع أديداس آخر إنتاج 2018الموديلات Telstar Elast Telstar Telstar Durlastأديداس تلستار 18تعديل - تعديل مصدري - تعديل ويكي بيانات كرة ال�...