React (JavaScripti raamistik)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] AjaluguReacti 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] KasutamineJä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 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>
IseärasusedÜhesuunaline andmete liikumineReacti 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] Virtuaalne DOMTeine 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. JSXReacti 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
Lisaks tavalistele HTML-i atribuutidele on võimalik kasutada vabalt valitud atribuute. Sellised parameetrid peavad olema lisatud
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 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 <div> <div>Section 1</div> <div>Section 2</div> <div>Section 3</div> </div> ReactJS-i kriitikaReactJS-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] Viited
|