React (ka React.js või ReactJS) on arvutiteaduses JavaScripti raamistik[1] kasutajaliideste loomiseks.
Seda haldavad Facebook, Instagram, üksikarendajate kogukond ja korporatsioonid.[2][3][4]
React võimaldab arendajatel luua suuremahulisi veebirakendusi, mis kasutavad andmeid ja muutuvad ajas, ilma et veebilehte uuesti laaditaks. Selle eesmärk on eelkõige kiiruse, lihtsuse ja skaleeritavuse tagamine. React tegeleb rakendustes ainult kasutajaliidestega. See vastab View osale Model-View-Controller (MVC) mudelis ning seda on võimalik kombineerida teiste JavaScripti teekide või raamistikega MVC mudelis, näiteks AngularJS.[5]
Reacti looja on Facebooki tarkvaraarendaja Jordan Walke. Idee sai alguse raamistikust XHP, mis on HTML-komponentide raamistik PHP-le.[6] See võeti esmakordselt kasutusele Facebooki ajajoonel 2011. aastal ja hiljem tehti seda ka veebilehel Instagram.com 2012. aastal.[7] Lähtekood avaldati JSConfi USA konverentsil 2013. aasta mais.
React Native, mis võimaldab Androidi, iOS-i, ja UWP rakenduste arendamist Reactiga, avaldati Facebooki React.js Confi konverentsil 2015. aasta veebruaris ja lähtekood avaldati 2015. aasta märtsis.
18. aprillil 2017 avaldas Facebook React Fiberi, Reacti raamistiku uue algoritmi kasutajaliideste loomiseks.[8] React Fiber on alus edaspidistele täiustustele ja uute funktsioonide arendamisele.[9]
Järgnev on algeline näide, kuidas kasutada Reacti HTML koodis, kasutades JSX-i ja ECMAScript 2015 JavaScripti süntaksit.
<div id="myReactApp"></div>
<script type="text/babel">
class Greeter extends React.Component {
render() {
return <h1>{this.props.greeting}</h1>
}
}
ReactDOM.render(<Greeter greeting="Hello World!" />, document.getElementById('myReactApp'));
</script>
Klass Greeter
on Reacti komponent, mis aktsepteerib argumenti greeting
. Meetod ReactDOM.render
loob isendi Greeter
komponendist, seab greeting
muutuja väärtuseks 'Hello World'
ja paigutab renderdatud komponendi alamelemendina DOM-elementi, mille id on myReactApp
.
Babel transpileerib ülaloleva ECMAScript 2015 koodi ES5 koodiks, mis näeb välja nii:
React.createElement(
"h1",
null,
this.props.greeting
);
Brauseris kuvades on tulemus järgmine:
<div id="myReactApp">
<h1>Hello World!</h1>
</div>
Sealhulgas on võimalik ka Reactis kuvada JSX-i läbi funktsiooniliste komponentide.
<div id="myReactApp"></div>
<script type="text/babel">
const Greeter = (props) => {
return <h1>{props.greeting}</h1>
}
ReactDOM.render(<Greeter greeting="Hello World!" />, document.getElementById('myReactApp'));
</script>
Reacti suurim potentsiaal on muutumatute parameetrite kasutamine komponentide vahel. Komponent ei tohi otseselt muuta ühtegi omadust, mis sellele anti. Selle asemel tuleb alamkomponendile anda kaasa funktsioon, mis muudab seda omadust ülemkomponendis. Teisisõnu omadused liiguvad komponentide suhtes ülevalt alla, aga andmetemuutused liiguvad funktsiooni kutsetena alt üles. Seda mehhanismi tuntakse nimega Flux.[10][11] Mitmeid Fluxi implementatsioone on loodud selle avaldamisest saati, kuid populaarseimaks on välja kujunenud Redux.[12]
Teine märkimisväärne detail on virtuaalne Document Object Model või teisisõnu virtuaalne DOM-i kasutamine. React hoiab mälus rakenduse andmestruktuuri, arvutab struktuuri muutumise korral erinevuse eelmise struktuuriga ja siis uuendab muutunud osad brauseri kuvatavas DOM-is efektiivselt.[13] See võimaldab arendajal programmeerida nii, justnagu renderdataks nagu terve leht muudatuse järel uuesti, kuigi React uuendab ainult need osad, mis tegelikult muutusid.
Reacti komponendid on tavaliselt kirjutatud JSX-i abil, mis on JavaScripti süntaksi laiendus, mis lubab kasutada HTML-notatsiooni ja HTML-märgendite süntaksit alamkomponentide renderdamiseks.[14] See on Reacti spetsiifiline grammatikalaiendus JavaScriptile nagu nüüdseks vananenud E4X. HTML-i süntaks töödeldakse Reacti raamistiku JavaScripti väljakutseteks. Arendajad võivad kirjutada ka puhtas JavaScriptis. JSX sarnaneb ka PHP-le Facebooki poolt välja töötatud süntaksilaiendusega XHP. JSX näeb välja nagu tavaline HTML. Näide JSX-koodist:
import React from 'react';
class App extends React.Component {
render() {
return (
<div>
<p>Header</p>
<p>Content</p>
<p>Footer</p>
</div>
);
}
}
export default App;
Elemendid peavad olema ümbritsetud konteinerelemendiga nagu <div>
element üleval näidatuna. Alates Reacti versioonist 16.0 on võimalik tagastada massiiv elementidest, fragmentidest ja sõnedest.[15]
Lisaks tavalistele HTML-i atribuutidele on võimalik kasutada vabalt valitud atribuute. Sellised parameetrid peavad olema lisatud data-
eesliitega. Versioonist 16.0 lastakse vabalt valitud atribuudid läbi DOM-i ilma data-
eesliiteta.[16]
JavaScripti väljendeid (aga mitte avaldisi) saab kasutada JSX-i sees koos loogeliste sulgudega {}
:
import React from 'react';
class App extends React.Component {
render() {
return (
<div>
<h1>{10+1}</h1>
</div>
);
}
}
export default App;
Ülalolev näide renderdub brauseris järgmiselt:
<div> <h1>11</h1> </div>
If-else avaldisi ei saa kasutada JSX-i sees, aga tingimuslikke avaldisi saab kasutada sellegipoolest kolmekomponendiliste väljenditena.
Allolev näide renderdab { i === 1 ? 'true' : 'false' }
sõnena 'true'
, sest i
on võrdne arvuga 1.
import React from 'react';
class App extends React.Component {
render() {
const i = 1;
return (
<div>
<h1>{ i === 1 ? 'true' : 'false' }</h1>
</div>
);
}
}
export default App;
Lisaks sõnede tagastamisele läbi tingimuslike operaatorite saab tagastada funktsioone ja koodifragmente.
import React from 'react';
class App extends React.Component {
render() {
const arr = [1, 2, 3];
return (
<div>
{
arr.length > 0 ?
arr.map(function(index) {
return (<div>Section {index}</div>)
})
: null
}
</div>
);
}
}
export default App;
Ülal näites kui arr
massiiv sisaldab elemente (neid on näites 3), siis renderdub järgmine:
<div> <div>Section 1</div> <div>Section 2</div> <div>Section 3</div> </div>
ReactJS-i murekohaks on suur mälu (RAM) kasutus, kuna see kasutab virtuaalse DOM-i kontseptsiooni. See tähendab, et kasutajaliidese kujutist hoitakse mälus ja sünkroonitakse reaalse DOM-iga, mille eest vastutab ReactDOM-i teek.[17]
{{netiviide}}
: CS1 hooldus: arhiivikoopia kasutusel pealkirjana (link)
{{netiviide}}
: CS1 hooldus: arhiivikoopia kasutusel pealkirjana (link)
{{netiviide}}
: CS1 hooldus: arhiivikoopia kasutusel pealkirjana (link)