RIOT.JS - Hızlı Kılavuz

RIOT.js, web uygulamaları geliştirmek için çok küçük boyutlu / hafif bir Web Bileşeni tabanlı UI kitaplığıdır. React.JS ve Polymer'in faydalarını çok kısa uygulama ve öğrenilmesi ve kullanılması için basit yapılarla birleştirir. Küçültülmüş versiyonu yaklaşık 10KB boyutundadır.

RIOT.js'nin temel özellikleri aşağıdadır

İfade Bağlamaları

  • DOM güncellemeleri ve yeniden akışlar sırasında çok küçük yük.

  • Değişiklikler, ana etiketlerden alt etiketlere / kontrollere doğru aşağı doğru yayılır.

  • Önceden derlenmiş ifadeleri kullanır ve bunları yüksek performans için önbelleğe alır.

  • Yaşam döngüsü olayları üzerinde iyi bir yorum sağlar.

Standartları İzler

  • Tescilli olay sistemi yok

  • Herhangi bir çoklu doldurma kitaplığına bağımlılık yok.

  • Mevcut HTML'ye hiçbir ekstra özellik eklenmedi.

  • JQuery ile iyi bütünleşir.

Temel değerler

RIOT.js aşağıdaki değerler dikkate alınarak geliştirilmiştir.

  • Basit ve minimalist.

  • Öğrenmesi ve uygulaması kolay.

  • Kullanıcı arayüzleri oluşturmak için Reaktif Görünümler sağlayın.

  • Bağımsız modüllerle API'ler oluşturmak için Etkinlik Kitaplığı sağlayın.

  • Tarayıcı geri düğmesiyle uygulama davranışına dikkat etmek için.

RIOT js kullanmanın iki yolu vardır.

  • Local Installation - Yerel makinenize RIOT kitaplığını indirebilir ve HTML kodunuza ekleyebilirsiniz.

  • CDN Based Version - RIOT kitaplığını HTML kodunuza doğrudan İçerik Dağıtım Ağı'ndan (CDN) dahil edebilirsiniz.

Yerel Kurulum

  • Şuraya git https://riot.js.org mevcut en son sürümü indirmek için.

  • Şimdi indirildi riot.min.js web sitenizin bir dizinindeki dosya, örneğin / riotjs.

Misal

Artık riotjs kitaplığını HTML dosyanıza aşağıdaki gibi ekleyebilirsiniz -

<!DOCTYPE html>
<html>
   <head>
      <script src = "/riotjs/riot.min.js"></script>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <messageTag></messageTag>
      <script>
         var tagHtml = "<h1>Hello World!</h1>";
         riot.tag("messageTag", tagHtml);
         riot.mount("messageTag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

CDN Tabanlı Sürüm

RIOT js kitaplığını HTML kodunuza doğrudan İçerik Dağıtım Ağı'ndan (CDN) dahil edebilirsiniz. Google ve Microsoft, en son sürüm için içerik teslimi sağlar.

Note - Bu eğitimde kitaplığın CDNJS sürümünü kullanıyoruz.

Misal

Şimdi yukarıdaki örneği CDNJS'deki jQuery kitaplığını kullanarak yeniden yazalım.

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <messageTag></messageTag>
      <script>
         var tagHtml = "<h1>Hello World!</h1>";
         riot.tag("messageTag", tagHtml);
         riot.mount("messageTag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

RIOT, özel, yeniden kullanılabilir html etiketleri oluşturarak çalışır. Bu etiketler Web bileşenlerine benzer ve sayfalarda ve web uygulamalarında yeniden kullanılabilir.

RIOT kullanma adımları

  • Html sayfasındaki riot.js dosyasını içe aktarın.

<head>
   <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
</head>
  • Bir komut dosyası bölümü başlatın ve etiket içeriğini html olarak tanımlayın. Öğreticide daha sonra göreceğimiz komut dosyası da dahil edilebilir.

var tagHtml = "<h1>Hello World!</h1>";
  • Riot.tag () yöntemini kullanarak bir etiket tanımlayın. Etiket, messageTag ve etiket içeriğini içeren değişkenin adını iletin.

riot.tag("messageTag", tagHtml);
  • Riot.mount () yöntemini kullanarak etiketi bağlayın. Etiketin adını, messageTag'i iletin. Bağlama işlemi messageTag'i html sayfasındaki tüm oluşumlarına bağlar. MessageTag etiketi, montajdan önce riot.js kullanılarak tanımlanmalıdır.

riot.mount("messageTag");
</script>

Tam örnek aşağıda verilmiştir.

Misal

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <messageTag></messageTag>
      <script>
         var tagHtml = "<h1>Hello World!</h1>";
         riot.tag("messageTag", tagHtml);
         riot.mount("messageTag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

RIOT, özel, yeniden kullanılabilir html etiketleri oluşturarak çalışır. Bu etiketler Web bileşenlerine benzer ve sayfalarda ve web uygulamalarında yeniden kullanılabilir. RIOT çerçevesini HTML sayfanıza dahil ettiğinizde, içe aktarılan js, bir isyan nesnesine işaret eden bir isyan değişkeni oluşturur. Bu nesne, etiket oluşturma ve bağlama gibi RIOT.js ile etkileşim için gerekli olan işlevleri içerir.

Etiketleri iki şekilde oluşturabilir ve kullanabiliriz.

  • Inline HTML- riot.tag () işlevini çağırarak. Bu işlev, bir etiket oluşturmak için etiket adını ve etiket tanımını alır. Etiket tanımı HTML, JavaScript ve CSS vb. İçerebilir.

  • Seperate Tag file- Etiket tanımını etiket dosyasında saklayarak. Bu etiket dosyası, bir etiket oluşturmak için etiket tanımını içerir. Bu dosyanın riot.tag () çağrısının yerine içe aktarılması gerekiyor.

<script src = "/riotjs/src/messageTag.tag" type = "riot/tag"></script<

Satır içi etiket örneği aşağıdadır.

Misal

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <messageTag></messageTag>
      <script>
         var tagHtml = "<h1>Hello World!</h1>";
         riot.tag("messageTag", tagHtml);
         riot.mount("messageTag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

Aşağıda harici dosya etiketi örneği verilmiştir.

Misal

messageTag.tag

<messageTag>
   <h1>Hello World!</h1>
</messageTag>

index.htm

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <messageTag></messageTag>
      <script src = "messageTag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("messageTag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

RIOT js, ifadeleri tanımlamak için {} kullanır. RIOT js, aşağıdaki ifade türlerine izin verir.

  • Simple Expression - Bir değişken tanımlayın ve bir etiket içinde kullanın.

<customTag>
   <h1>{title}</h1>
   <script>
      this.title = "Welcome to TutorialsPoint.COM";
   </script>
</customTag>
  • Evaluate Expression - Bir işlemde kullanırken bir değişkeni değerlendirin.

<customTag>
   <h2>{val * 5}</h2>
   <script>
      this.val = 4;
   </script>
</customTag>
  • Get value from Options object - Öznitelikler aracılığıyla etikete iletilen değeri almak için.

Misal

Aşağıda, yukarıdaki kavramların tam örneği verilmiştir.

customTag.tag

<customTag>
   <h1>{title}</h1>
   <h2>{val * 5}</h2>
   <h2>{opts.color}</h2>
   <script>
      this.title = "Welcome to TutorialsPoint.COM";
      this.val = 4;
   </script>
</customTag>

index.htm

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <customTag color="red"></customTag>
      <script src = "customTag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("customTag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

RIOT js etiketlerinin kendi stilleri olabilir ve etiketler içinde sadece etiketin içindeki içeriği etkileyecek stilleri tanımlayabiliriz. Ayrıca bir etiket içinde betik kullanarak da bir stil sınıfı belirleyebiliriz. Aşağıda, RIOT etiketlerinin stilinin nasıl elde edileceği anlatılmaktadır.

custom1Tag.tag

<custom1Tag>
   <h1>{title}</h1>
   <h2 class = "subTitleClass">{subTitle}</h2>
   <style>
   h1 {
      color: red;
   }
   .subHeader {
      color: green;
   }
   </style>
   <script>
      this.title = "Welcome to TutorialsPoint.COM";
      this.subTitle = "Learning RIOT JS";
      this.subTitleClass = "subHeader";
   </script>
</custom1Tag>

index.htm

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <h1>Non RIOT Heading</h1>
      <custom1Tag></custom1Tag>
      <script src = "custom1Tag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("custom1Tag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

Koşul ifadeleri, RIOT etiketlerinin öğelerini göstermek / gizlemek için kullanılan yapılardır. Aşağıda, RIOT'un desteklediği üç koşul bulunmaktadır:

  • if - aktarılan değere göre öğe ekleme / kaldırma.

<custom2Tag>
   <h2 if = {showMessage}>Using if!</h2>
   <script>
      this.showMessage = true;      
   </script>
</custom2Tag>
  • show - style = "kullanan bir öğeyi gösterirdisplay:' ' "doğru geçerse.

<custom2Tag>
   <h2 show = {showMessage}>Using show!</h2>
   <script>
      this.showMessage = true;      
   </script>
</custom2Tag>
  • hide - style = "kullanarak bir öğeyi gizlerdisplay:'none' "doğru geçerse.

<custom2Tag>
   <h2 show = {showMessage}>Using show!</h2>
   <script>
      this.showMessage = true;      
   </script>
</custom2Tag>

Misal

Tam örnek aşağıda verilmiştir.

custom2Tag.tag

<custom2Tag>
   <h2 if = {showMessage}>Using if!</h2>
   <h2 if = {show}>Welcome!</h1>
   <h2 show = {showMessage}>Using show!</h2>
   <h2 hide = {show}>Using hide!</h2>
   <script>
      this.showMessage = true;
      this.show = false; 
   </script>
</custom2Tag>

custom2.htm

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <custom2Tag></custom2Tag>
      <script src = "custom2Tag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("custom2Tag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

Verim, harici html içeriğini bir RIOT etiketine yerleştirmek için bir mekanizmadır. Verim yapmanın birçok yolu vardır.

  • Simple Yield- Etiketteki tek bir yer tutucuyu değiştirmek istiyorsak. O zaman bu mekanizmayı kullanın.

<custom3Tag>
   Hello <yield/>
</custom3Tag>
<custom3Tag><b>User</b></custom3Tag>
  • Multiple Yield- Etiketteki birden çok yer tutucuyu değiştirmek istiyorsak. O zaman bu mekanizmayı kullanın.

<custom4Tag>
   <br/><br/>
   Hello
   <yield from = "first"/>
   <br/><br/>
   Hello 
   <yield from = "second"/>
</custom4Tag>
<custom4Tag>
   <yield to = "first">User 1</yield>
   <yield to = "second">User 2</yield>
</custom4Tag>

Misal

Tam örnek aşağıda verilmiştir.

custom3Tag.tag

<custom3Tag>
   Hello <yield/>
</custom3Tag>

custom4Tag.tag

<custom4Tag>
   <br/><br/>
   Hello
   <yield from = "first"/>
   <br/><br/>
   Hello 
   <yield from = "second"/>
</custom4Tag>

custom3.htm

<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <custom3Tag><b>User</b></custom3Tag>
      <custom4Tag>
         <yield to = "first">User 1</yield>
         <yield to = "second">User 2</yield>
      </custom4Tag>   
      <script src = "custom3Tag.tag" type = "riot/tag"></script>
      <script src = "custom4Tag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("custom3Tag");
         riot.mount("custom4Tag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

HTML öğelerine, refs nesnesini kullanarak HTML öğelerine nasıl eriştiğimize benzer şekilde olay ekleyebiliriz. İlk adım olarak, bir DOM öğesine bir ref niteliği ekleriz ve etiketin komut dosyası bloğundaki this.ref kullanarak ona erişiriz.

  • Attach ref - Bir DOM öğesine ref özelliği ekleyin.

<button ref = "clickButton">Click Me!</button>
  • Use the refs object- Şimdi mount olayında refs nesnesini kullanın. Bu olay, RIOT özel etiketi bağladığında ve refs nesnesini doldurduğunda tetiklenir.

this.on("mount", function() {
   console.log("Mounting");
   console.log(this.refs.username.value);
})

Misal

Tam örnek aşağıda verilmiştir.

custom5Tag.tag

<custom5Tag>
   <form>
      <input ref = "username" type = "text" value = "Mahesh"/>
      <input type = "submit" value = "Click Me!" />
   </form>
   <script>
      this.on("mount", function() {
         console.log("Mounting");
         console.log(this.refs.username.value); 
      })
   </script>
</custom5Tag>

custom5.htm

<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <custom5Tag></custom5Tag>
      <script src = "custom5Tag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("custom5Tag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

HTML elemanlarına refs nesnesini kullanarak erişebiliriz. İlk adım olarak, bir DOM öğesine bir ref niteliği ekleriz ve etiketin komut dosyası bloğundaki this.ref kullanarak ona erişiriz.

  • Attach ref - Bir DOM öğesine ref özelliği ekleyin.

<button ref = "clickButton">Click Me!</button>
  • Use the refs object- Şimdi mount olayında refs nesnesini kullanın. Bu olay, RIOT özel etiketi bağladığında ve refs nesnesini doldurduğunda tetiklenir.

this.on("mount", function() {
   this.refs.clickButton.onclick = function(e) {
      console.log("clickButton clicked");
      return false;
   };
})

Misal

Tam örnek aşağıda verilmiştir.

custom6Tag.tag

<custom6Tag>
   <form ref = "customForm">
      <input ref = "username" type = "text" value = "Mahesh"/>
      <button ref = "clickButton">Click Me!</button>
      <input type = "submit" value = "Submit" />
   </form>
   <script>
      this.on("mount", function() {
         this.refs.clickButton.onclick = function(e) {
            console.log("clickButton clicked");
            return false;
         };
         this.refs.customForm.onsubmit = function(e) {
            console.log("Form submitted");
            return false;
         };
      }) 
   </script>
</custom6Tag>

custom6.htm

<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <custom6Tag></custom6Tag>
      <script src = "custom6Tag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("custom6Tag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

RIOT ilkel dizilerinde veya Nesnelerde yineleme yapabilir ve hareket halindeyken html öğelerini oluşturabilir / güncelleyebiliriz. "Her" yapıyı kullanarak bunu başarabiliriz.

  • Create array - Bir nesne dizisi oluşturun.

this.cities = [
   { city : "Shanghai" , country:"China" , done: true },
   { city : "Seoul"    , country:"South Korea" },
   { city : "Moscow"   , country:"Russia"      }
];
  • Add each attribute - Şimdi "her" özelliğini kullanın.

<ul>
   <li each = { cities } ></li>
</ul>
  • Iterate array of objects - Nesne özelliklerini kullanarak diziyi yineleyin.

<input type = "checkbox" checked = { done }> { city } - { country }

Misal

Tam örnek aşağıda verilmiştir.

custom7Tag.tag

<custom7Tag>
   <style>
      ul {
         list-style-type: none;
      }
   </style>
   <ul>
      <li each = { cities } >
         <input type = "checkbox" checked = { done }> { city } - { country }
      </li>
   </ul>
   <script>
      this.cities = [
         { city : "Shanghai" , country:"China" , done: true },
         { city : "Seoul"    , country:"South Korea" },
         { city : "Moscow"   , country:"Russia"      }
      ]; 
   </script>
</custom7Tag>

custom7.htm

<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <custom7Tag></custom6Tag>
      <script src = "custom7Tag.tag" type = "riot/tag"></script>
      <script>
         riot.mount("custom7Tag");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

Mixin aracılığıyla, etiketler arasında ortak işlevselliği paylaşabiliriz. Mixin bir işlev, sınıf veya nesne olabilir. Her bir etiketin kullanması gereken bir Kimlik Doğrulama Hizmeti durumunu düşünün.

  • Define Mixin - mount () öğesini çağırmadan önce riot.mixin () yöntemini kullanarak mixin tanımlayın.

riot.mixin('authService', {
   init: function() {
      console.log('AuthService Created!')
   },

   login: function(user, password) {
      if(user == "admin" && password == "admin"){
         return 'User is authentic!'
      }else{
         return 'Authentication failed!'
      }   
   }
});
  • Initialize mixin - Her etikette mixin'i başlatın.

this.mixin('authService')
  • Use mixin - Başlattıktan sonra, mixin etiket içinde kullanılabilir.

this.message = this.login("admin","admin");

Misal

Tam örnek aşağıda verilmiştir.

custom8Tag.tag

<custom8Tag>
   <h1>{ message }</h1>
   <script>
      this.mixin('authService')
      this.message = this.login("admin","admin")
   </script>
</custom8Tag>

custom9Tag.tag

<custom9Tag>
   <h1>{ message }</h1>
   <script>
      this.mixin('authService')
      this.message = this.login("admin1","admin")
   </script>
</custom9Tag>

custom8.htm

<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <custom8Tag></custom8Tag>
      <custom9Tag></custom9Tag>
      <script src = "custom8Tag.tag" type = "riot/tag"></script>
      <script src = "custom9Tag.tag" type = "riot/tag"></script>
      <script>
         riot.mixin('authService', {
            init: function() {
               console.log('AuthService Created!')
            },
            login: function(user, password) {
               if(user == "admin" && password == "admin"){
                  return 'User is authentic!'
               }else{
                  return 'Authentication failed!'
               }   
            }
         });
         riot.mount("*");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

Gözlemlenebilir mekanizma, RIOT'un olayları bir etiketten diğerine göndermesine izin verir. Aşağıdaki API'ler, RIOT gözlemlenebilirlerini anlamak için önemlidir.

  • riot.observable(element)- Verilen nesne öğesi için Gözlemci desteği ekler veya bağımsız değişken boşsa yeni bir gözlemlenebilir örnek oluşturulur ve döndürülür. Bundan sonra nesne olayları tetikleyebilir ve dinleyebilir.

var EventBus = function(){
   riot.observable(this);
}
  • element.trigger(events) - Verilen olayı dinleyen tüm geri arama işlevlerini yürütün.

sendMessage() {
   riot.eventBus.trigger('message', 'Custom 10 Button Clicked!');    
}
  • element.on(events, callback) - Verilen olayı dinleyin ve her olay tetiklendiğinde geri aramayı yürütün.

riot.eventBus.on('message', function(input) {      
   console.log(input);
});

Misal

Tam örnek aşağıda verilmiştir.

custom10Tag.tag

<custom10Tag>
   <button onclick = {sendMessage}>Custom 10</button>
   <script>
      sendMessage() {
         riot.eventBus.trigger('message', 'Custom 10 Button Clicked!');    
      }
   </script>    
</custom10Tag>

custom11Tag.tag

<custom11Tag>
   <script>
      riot.eventBus.on('message', function(input) {      
         console.log(input);
      });
   </script>    
</custom11Tag>

custom9.htm

<html>
   <head>
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/riot/3.13.2/riot+compiler.min.js"></script>
   </head>
   <body>
      <custom10Tag></custom10Tag>
      <custom11Tag></custom11Tag>
      <script src = "custom10Tag.tag" type = "riot/tag"></script>
      <script src = "custom11Tag.tag" type = "riot/tag"></script>
      <script>
         var EventBus = function(){
            riot.observable(this);
         }
         riot.eventBus = new EventBus();
         riot.mount("*");
      </script>
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -