ReactJS - JSX

React şablon oluşturmak için normal JavaScript yerine JSX kullanır. Kullanmak gerekli değildir, ancak onunla birlikte gelen bazı artılar aşağıdadır.

  • JavaScript'e kod derlerken optimizasyon gerçekleştirdiği için daha hızlıdır.

  • Ayrıca tür açısından güvenlidir ve hataların çoğu derleme sırasında yakalanabilir.

  • HTML konusunda bilgiliyseniz, şablon yazmayı daha kolay ve daha hızlı hale getirir.

JSX kullanma

JSX, çoğu durumda normal bir HTML gibi görünür. Bunu zaten Ortam Kurulum bölümünde kullandık. Koda bakApp.jsx nereye dönüyoruz div.

App.jsx

import React from 'react';

class App extends React.Component {
   render() {
      return (
         <div>
            Hello World!!!
         </div>
      );
   }
}
export default App;

HTML'ye benzer olsa da, JSX ile çalışırken aklımızda tutmamız gereken birkaç şey var.

İç içe Elemanlar

Daha fazla öğe döndürmek istiyorsak, onu tek bir kap öğesi ile sarmamız gerekir. Nasıl kullandığımıza dikkat edindiv için bir paketleyici olarak h1, h2 ve p elementler.

App.jsx

import React from 'react';

class App extends React.Component {
   render() {
      return (
         <div>
            <h1>Header</h1>
            <h2>Content</h2>
            <p>This is the content!!!</p>
         </div>
      );
   }
}
export default App;

Öznitellikler

Normal HTML özellikleri ve niteliklerine ek olarak kendi özel niteliklerimizi kullanabiliriz. Özel nitelik eklemek istediğimizde, kullanmamız gerekirdata-önek. Aşağıdaki örnekte ekledikdata-myattribute özniteliği olarak p öğesi.

import React from 'react';

class App extends React.Component {
   render() {
      return (
         <div>
            <h1>Header</h1>
            <h2>Content</h2>
            <p data-myattribute = "somevalue">This is the content!!!</p>
         </div>
      );
   }
}
export default App;

JavaScript İfadeleri

JavaScript ifadeleri JSX içinde kullanılabilir. Sadece onu kıvrımlı parantezlerle sarmamız gerekiyor{}. Aşağıdaki örnek,2.

import React from 'react';

class App extends React.Component {
   render() {
      return (
         <div>
            <h1>{1+1}</h1>
         </div>
      );
   }
}
export default App;

Kullanamayız if else JSX içindeki ifadeler yerine kullanabiliriz conditional (ternary)ifade. Aşağıdaki örnekte değişkeni eşittir 1 böylece tarayıcı işleyecek true, Onu başka bir değerle değiştirirsek, false.

import React from 'react';

class App extends React.Component {
   render() {
      var i = 1;
      return (
         <div>
            <h1>{i == 1 ? 'True!' : 'False'}</h1>
         </div>
      );
   }
}
export default App;

Şekillendirme

React, satır içi stilleri kullanmanızı önerir. Satır içi stilleri ayarlamak istediğimizde, kullanmamız gerekircamelCasesözdizimi. React ayrıca otomatik olarakpxbelirli öğelerdeki sayı değerinden sonra. Aşağıdaki örnek, nasıl ekleneceğini gösterirmyStyle satır içi h1 öğesi.

import React from 'react';

class App extends React.Component {
   render() {
      var myStyle = {
         fontSize: 100,
         color: '#FF0000'
      }
      return (
         <div>
            <h1 style = {myStyle}>Header</h1>
         </div>
      );
   }
}
export default App;

Yorumlar

Yorum yazarken küme parantezleri koymamız gerekir {}Bir etiketin alt bölümünde yorum yazmak istediğimizde. Her zaman kullanmak iyi bir uygulamadır{} yorum yazarken, çünkü uygulamayı yazarken tutarlı olmak istiyoruz.

import React from 'react';

class App extends React.Component {
   render() {
      return (
         <div>
            <h1>Header</h1>
            {//End of the line Comment...}
            {/*Multi line comment...*/}
         </div>
      );
   }
}
export default App;

Adlandırma kuralı

HTML etiketleri her zaman kullanır lowercase etiket adları, React bileşenleri ise Uppercase.

Note - Kullanmalısın className ve htmlFor yerine XML özellik adları olarak class ve for.

Bu, React resmi sayfasında şu şekilde açıklanmaktadır:

JSX JavaScript olduğundan, aşağıdaki gibi tanımlayıcılar class ve forXML öznitelik adları olarak önerilmemektedir. Bunun yerine, React DOM bileşenleri, aşağıdaki gibi DOM özellik adlarını bekler:className ve htmlFor, sırasıyla.