Meteor - Hızlı Kılavuz

Meteor resmi belgelerine göre -

Meteor, modern web ve mobil uygulamalar geliştirmek için eksiksiz bir JavaScript platformudur. Meteor, bağlantılı istemci reaktif uygulamaları oluşturmak için bir dizi önemli teknoloji, bir oluşturma aracı ve Node.js ve genel JavaScript topluluğundan seçilmiş bir paket kümesi içerir.

Özellikleri

  • Web and Mobile - Meteor, Web, Android ve IOS uygulamaları geliştirmek için bir platform sunar.

  • Universal Apps - Web tarayıcıları ve mobil cihazlar için aynı kod.

  • Packages - Kurulumu ve kullanımı kolay çok sayıda paket.

  • Meteor Galaxy - Meteor uygulama dağıtımı için bulut hizmeti.

Avantajlar

  • Geliştiriciler, sunucu ve istemci tarafı geliştirme için yalnızca JavaScript'e ihtiyaç duyar.
  • Kodlama çok basit ve başlangıç ​​dostu.
  • Meteor uygulamaları varsayılan olarak gerçek zamanlıdır.
  • Resmi ve topluluk paketleri çok büyük zaman tasarrufu sağlar.

Sınırlamalar

  • Meteor, büyük ve karmaşık uygulamalar için pek uygun değildir.

  • Meteor ile çalışırken çok fazla sihir var, bu yüzden geliştiriciler kendilerini bir şekilde sınırlı bulabilirler.

Bu bölümde Meteor'un Windows işletim sistemine nasıl kurulacağını öğreneceğiz. Meteor ile çalışmaya başlamadan önce, ihtiyacımız olacakNodeJS. Yüklemediyseniz, aşağıda verilen bağlantıları kontrol edebilirsiniz.

Önkoşul

NodeJS, Meteor gelişimi için gerekli platformdur. NodeJS ortam kurulumunuz hazır değilse,NodeJS Environment Setup.

Meteor'u yükleyin

Resmi meteor yükleyicisini bu sayfadan indirin

Yükleme sırasında herhangi bir hata oluşursa, yükleyiciyi yönetici olarak çalıştırmayı deneyin. Kurulum tamamlandığında, bir Meteor hesabı oluşturmanız istenecektir.

Meteor yükleyiciyi kurmayı bitirdiğinizde, komut istemi penceresinde aşağıdaki kodu çalıştırarak her şeyin doğru kurulup kurulmadığını test edebilirsiniz.

C:\Users\username>meteor

Aşağıdaki çıktı olacaktır -

Bu bölümde, ilk Meteor uygulamanızı nasıl oluşturacağınızı öğreneceğiz.

Adım 1 - Uygulamayı Oluşturun

Uygulamayı oluşturmak için, meteor createkomut istemi penceresinden komut. Uygulama adı olacakmeteorApp.

C:\Users\username\Desktop\Meteor>meteor create meteorApp

Adım 2 - Uygulamayı Çalıştırın

Uygulamayı yazarak çalıştırabiliriz. meteor komut.

C:\Users\username\Desktop\meteorApp>meteor

Bu komut, aşağıdaki resimde görülebilen birkaç işlemi başlatacaktır.

Adım 3 - Sonucu Doğrulayın

Şimdi açabiliriz http://localhost:3000/ İlk Meteor Uygulamamızın nasıl göründüğünü görmek için adres.

Meteor şablonları üç üst düzey etiket kullanıyor. İlk ikisihead ve body. Bu etiketler, normal HTML'deki ile aynı işlevleri yerine getirir. Üçüncü etikettemplate. HTML'yi JavaScript'e bağladığımız yer burası.

Basit Şablon

Aşağıdaki örnek bunun nasıl çalıştığını göstermektedir. İle bir şablon oluşturuyoruzname = "myParagraph"öznitelik. bizimtemplate etiketi altında oluşturulur bodyöğesi, ancak ekranda görüntülenmeden önce eklememiz gerekir. Kullanarak yapabiliriz{{> myParagraph}}sözdizimi. Şablonumuzda çift küme parantezi kullanıyoruz({{text}}). Bu meteor şablon dilidirSpacebars.

JavaScript dosyamızda, Template.myParagraph.helpers({})şablonumuzla bağlantımız olacak yöntem. Biz sadece kullanıyoruztext bu örnekte yardımcı.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <h1>Header</h1>
   {{> myParagraph}}
</body>
 
<template name = "myParagraph">
   <p>{{text}}</p>
</template>

meteorApp.js

if (Meteor.isClient) {
   
   // This code only runs on the client
   Template.myParagraph.helpers({
      text: 'This is paragraph...'
   });
}

Değişiklikleri kaydettikten sonra, aşağıdaki çıktı olacaktır -

Blok Şablonu

Aşağıdaki örnekte kullanıyoruz {{#each paragraphs}} üzerinde yinelemek paragraphs dizi ve dönüş şablonu name = "paragraph" her değer için.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{#each paragraphs}}
         {{> paragraph}}
      {{/each}}
   </div>
</body>
 
<template name = "paragraph">
   <p>{{text}}</p>
</template>

Yaratmalıyız paragraphsyardımcı. Bu, beş metin değerine sahip bir dizi olacaktır.

meteorApp.js

if (Meteor.isClient) {
   
   // This code only runs on the client
   Template.body.helpers({
      paragraphs: [
         { text: "This is paragraph 1..." },
         { text: "This is paragraph 2..." },
         { text: "This is paragraph 3..." },
         { text: "This is paragraph 4..." },
         { text: "This is paragraph 5..." }
      ]
   });
}

Şimdi ekranda beş paragraf görebiliriz.

Bu bölümde nasıl kullanılacağını öğreneceğiz MongoDB koleksiyonlar.

Koleksiyon Oluşturun

Aşağıdaki kodla yeni bir koleksiyon oluşturabiliriz -

meteorApp.js

MyCollection = new Mongo.Collection('myCollection');

Veri ekle

Koleksiyon oluşturulduktan sonra, insert yöntem.

meteorApp.js

MyCollection = new Mongo.Collection('myCollection');

var myData = {
   key1: "value 1...",
   key2: "value 2...",
   key3: "value 3...",
   key4: "value 4...",
   key5: "value 5..."
}

MyCollection.insert(myData);

Veri Bul

Kullanabiliriz find koleksiyondaki verileri arama yöntemi.

meteorApp.js

MyCollection = new Mongo.Collection('myCollection');

var myData = {
   key1: "value 1...",
   key2: "value 2...",
   key3: "value 3...",
   key4: "value 4...",
   key5: "value 5..."
}

MyCollection.insert(myData);

var findCollection = MyCollection.find().fetch();
console.log(findCollection);

Konsol, daha önce eklediğimiz verileri gösterecektir.

Arama parametrelerini ekleyerek aynı sonucu elde edebiliriz.

meteorApp.js

MyCollection = new Mongo.Collection('myCollection');

var myData = {
   key1: "value 1...",
   key2: "value 2...",
   key3: "value 3...",
   key4: "value 4...",
   key5: "value 5..."
}

MyCollection.insert(myData);

var findCollection = MyCollection.find({key1: "value 1..."}).fetch();
console.log(findCollection);

Veriyi güncelle

Bir sonraki adım, verilerimizi güncellemektir. Bir koleksiyon oluşturduktan ve yeni veriler ekledikten sonra,update yöntem.

meteorApp.js

MyCollection = new Mongo.Collection('myCollection');

var myData = {
   key1: "value 1...",
   key2: "value 2...",
   key3: "value 3...",
   key4: "value 4...",
   key5: "value 5..."
}

MyCollection.insert(myData);

var findCollection = MyCollection.find().fetch();
var myId = findCollection[0]._id;

var updatedData = {
   key1: "updated value 1...",
   key2: "updated value 2...",
   key3: "updated value 3...",
   key4: "updated value 4...",
   key5: "updated value 5..."
}

MyCollection.update(myId, updatedData);

var findUpdatedCollection = MyCollection.find().fetch();
console.log(findUpdatedCollection);

Konsol, koleksiyonumuzun güncellendiğini gösterecektir.

Verileri Sil

Veriler, koleksiyondan silinebilir. removeyöntem. Biz ayarlıyoruzid bu örnekte, belirli verileri silmek için bir parametre olarak.

meteorApp.js

MyCollection = new Mongo.Collection('myCollection');

var myData = {
   key1: "value 1...",
   key2: "value 2...",
   key3: "value 3...",
   key4: "value 4...",
   key5: "value 5..."
}

MyCollection.insert(myData);

var findCollection = MyCollection.find().fetch();
var myId = findCollection[0]._id;

MyCollection.remove(myId);

var findDeletedCollection = MyCollection.find().fetch();
console.log(findDeletedCollection);

Konsol boş bir dizi gösterecektir.

Koleksiyondaki her şeyi silmek istiyorsak, aynı yöntemi kullanabiliriz, ancak bunun yerine id boş bir nesne kullanacağız {}. Bunu güvenlik nedeniyle sunucuda yapmamız gerekiyor.

meteorApp.js

if (Meteor.isServer) {

   MyCollection = new Mongo.Collection('myCollection');

   var myData = {
      key1: "value 1...",
      key2: "value 2...",
      key3: "value 3...",
      key4: "value 4...",
      key5: "value 5..."
   }

   MyCollection.insert(myData);
   MyCollection.remove({});
	
   var findDeletedCollection = MyCollection.find().fetch();
   console.log(findDeletedCollection);
}

Diğer parametreleri kullanarak da verileri silebiliriz. Önceki örnekte olduğu gibi, Meteor bizi bunu sunucudan yapmaya zorlayacaktır.

meteorApp.js

if (Meteor.isServer) {

   MyCollection = new Mongo.Collection('myCollection');

   var myData = {
      key1: "value 1...",
      key2: "value 2...",
      key3: "value 3...",
      key4: "value 4...",
      key5: "value 5..."
   }

   MyCollection.insert(myData);
   MyCollection.remove({key1: "value 1..."});
	
   var findDeletedCollection = MyCollection.find().fetch();
   console.log(findDeletedCollection);
}

Verilerin komut penceresinden silindiği görülebilir.

Bu bölümde, Meteor formlarıyla nasıl çalışılacağını öğreneceğiz.

Metin Girişi

İlk önce bir form metin giriş alanı ve gönder düğmesi olan öğe.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
   <form>
      <input type = "text" name = "myForm">
      <input type = "submit" value = "SUBMIT">
   </form>
</template>

Bir JavaScript dosyasında, submitEtkinlik. Tarayıcının yenilenmesini durdurmak için varsayılan olay davranışını önlememiz gerekir. Daha sonra, giriş alanının içeriğini alacağız ve bunu şuna atayacağız:textValue değişken.

Aşağıdaki örnekte, bu içeriği yalnızca geliştirici konsoluna kaydedeceğiz. Ve ihtiyacımız olan son şey giriş alanını temizlemek.

meteorApp.js

if (Meteor.isClient) {

   Template.myTemplate.events({

      'submit form': function(event) {
         event.preventDefault();
         var textValue = event.target.myForm.value;
         console.log(textValue);
         event.target.myForm.value = "";
      }
   });
}

Giriş alanımıza "Bazı metin ..." yazıp gönderdiğimizde, konsol girdiğimiz metni günlüğe kaydedecektir.

Radyo Düğmeleri

Radyo düğmeleri için benzer bir konsept kullanılabilir.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
   <form>
      <input type = "radio" name = "myForm" value = "form-1">FORM 1
      <input type = "radio" name = "myForm" value = "form-2">FORM 2
      <input type = "submit" value = "SUBMIT">
   </form>
</template>

meteorApp.js

if (Meteor.isClient) {

   Template.myTemplate.events({

      'submit form': function(event) {
         event.preventDefault();
         var radioValue = event.target.myForm.value;
         console.log(radioValue);
      }
   });
}

İlk butonu gönderdiğimizde konsol aşağıdaki çıktıyı gösterecektir.

Onay kutusu

Aşağıdaki örnek, onay kutularının nasıl kullanılacağını gösterir. Sadece aynı süreci tekrarladığımızı görebilirsiniz.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
   <form>
      <input type = "checkbox" name = "myForm" value = "form-1">FORM 1
      <input type = "checkbox" name = "myForm" value = "form-2">FORM 2
      <input type = "submit" value = "SUBMIT">
   </form>
</template>

meteorApp.js

if (Meteor.isClient) {

   Template.myTemplate.events({
   
      'submit form': function(event) {
         event.preventDefault();
         var checkboxValue1 = event.target.myForm[0].checked;
         var checkboxValue2 = event.target.myForm[1].checked;
         console.log(checkboxValue1);
         console.log(checkboxValue2);
      }
   });
}

Form gönderildikten sonra, kontrol edilen giriş olarak günlüğe kaydedilecektir true, işaretlenmemiş olan şu şekilde kaydedilir: false.

Açılır Menüyü Seçin

Aşağıdaki örnekte, nasıl kullanılacağını öğreneceğiz selectöğesi. Kullanacağızchange Seçenek her değiştiğinde verileri güncellemek için olay.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
   <select>
      <option name = "myOption" value = "option-1">OPTION 1</option>
      <option name = "myOption" value = "option-2">OPTION 2</option>
      <option name = "myOption" value = "option-3">OPTION 3</option>
      <option name = "myOption" value = "option-4">OPTION 4</option>
   </select>
</template>

meteorApp.js

if (Meteor.isClient) {

   Template.myTemplate.events({

      'change select': function(event) {
         event.preventDefault();
         var selectValue = event.target.value;
         console.log(selectValue);
      }
   });
}

Üçüncü seçeneği seçersek, konsol seçenek değerini günlüğe kaydedecektir.

Bu bölümde nasıl kullanılacağını öğreneceğiz tag, class ve idbir olay seçici olarak. Etkinliklerle çalışmak oldukça basittir.

HTML şablonunda üç öğe oluşturalım. Birincisipikincisi myClass sınıf ve sonuncusu myId İD.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
   <p>PARAGRAPH...</p>
   <button class = "myClass">CLASS</button>
   <button id = "myId">ID</button>
</template>

JavaScript dosyamızda, yukarıda oluşturduğumuz üç öğe için üç etkinlik ayarlıyoruz. Sadece eklediğimizi görebilirsinizp, .myClass ve #myId sonra clickEtkinlik. Bunlarselectors yukarıda bahsettik.

meteorApp.js

if (Meteor.isClient) {

   Template.myTemplate.events({

      'click p': function() {
         console.log("The PARAGRAPH is clicked...");
      },

      'click .myClass': function() {
         console.log("The CLASS is clicked...");
      },

      'click #myId': function() {
         console.log("The ID is clicked...");
      },
   });
}

Bunu test etmek için önce PARAGRAPH, sonra CLASS düğmesi ve son olarak IDbuton. Aşağıdaki konsol günlüğünü alacağız.

Diğer tüm JavaScript olaylarını (tıklama, dbclick, bağlam menüsü, fare aşağı, fareyle üzerine gelme, fareyle üzerine gelme, fareyle üzerine gelme, fare imleci) kullanabiliriz.

Oturumlar, kullanıcılar uygulamayı kullanırken verileri kaydetmek için kullanılır. Bu veriler, kullanıcı uygulamadan ayrıldığında silinecektir.

Bu bölümde, bir oturum nesnesini nasıl ayarlayacağımızı, bazı verileri nasıl saklayacağımızı ve bu verileri nasıl iade edeceğimizi öğreneceğiz. Temel HTML kurulumunu kullanacağız.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
</template>

Şimdi saklayacağız myData yerel olarak kullanarak Session.set()yöntem. Yöntem ayarlandıktan sonra, onu kullanarak geri döndürebilirizSession.get() yöntem.

meteorApp.js

if (Meteor.isClient) {
  
   var myData = {
      key1: "value1",
      key2: "value2"
   }

   Session.set('mySession', myData);

   var sessionDataToLog = Session.get('mySession');
   console.log(sessionDataToLog);
}

Konsolu kontrol edersek, depolanan verilerin loglandığını göreceğiz.

Sonraki bölümde, Session değişkenini kullanarak şablonların nasıl otomatik olarak güncelleneceğini öğreneceğiz.

İzleyici, Oturum değişkeni değiştiğinde şablonları otomatik olarak güncellemek için kullanılan küçük bir kitaplıktır. Bu bölümde, izleyicinin nasıl çalıştığını öğreneceğiz.

İlk önce bir button bu, oturumu güncellemek için kullanılacak.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
   <button id = "myButton">CLICK ME</button>
</template>

Ardından, başlangıç ​​oturumu değerini ayarlayacağız myData ve bir mySession nesne. Tracker.autorun yöntem göz kulak olmak için kullanılır mySession. Bu nesne her değiştiğinde, şablon otomatik olarak güncellenir. Test etmek için, güncelleme için bir tıklama etkinliği ayarlayacağız.

meteorApp.js

if (Meteor.isClient) {
  
   var myData = 0
   Session.set('mySession', myData);

   Tracker.autorun(function () {
      var sessionData = Session.get('mySession');
      console.log(sessionData)
   });

   Template.myTemplate.events({

      'click #myButton': function() {
         Session.set('mySession', myData ++);
      }
   });
}

Tıklarsak CLICK ME düğmesine beş kez, izleyicinin oturum her güncellendiğinde yeni değerler kaydettiğini göreceğiz.

Meteor, uygulamanızı geliştirirken kullanabileceğiniz binlerce topluluk paketi sunar.

Paket Ekleme

Resmi Meteor paket sunucusunu buradan kontrol edebilirsiniz . İhtiyacınız olan paketi arayın ve komut istemi penceresine ekleyin. Örneğin, eklemek istiyorsanızhttp uygulamanızı paketlemek için aşağıdaki kodu çalıştırarak yapabilirsiniz -

C:\Users\username\Desktop\meteorApp>meteor add http

Paketleri Çıkarma

Paketleri kaldırmak için benzer bir ilke kullanılabilir -

C:\Users\username\Desktop\meteorApp>meteor remove http

Paketleri Güncelleme

Aşağıdaki kodu çalıştıran paketi güncelleyebilirsiniz -

C:\Users\username\Desktop\meteorApp>meteor update http

Güncel Paketleri Kontrol Etmek

Mevcut uygulamanızın hangi paketleri kullandığını da kontrol edebilirsiniz.

C:\Users\username\Desktop\meteorApp>meteor list

Paket Bakımı

Bir pakette : isminde, bir topluluk paketi anlamına gelirken, öneksiz olanlar Meteor Geliştirme grubu tarafından korunur.

Meteor Geliştirme Grubu Paketi Ekleniyor

C:\Users\username\Desktop\meteorApp>meteor add http

Topluluk Paketi Ekleniyor

C:\Users\username\Desktop\meteorApp>meteor add cfs:http-methods

Kodu yalnızca sunucuda veya istemci tarafında çalışacak şekilde sınırlamak istiyorsanız, aşağıdaki kodu kullanabilirsiniz -

meteorApp.js

if (Meteor.isClient) {
   // Code running on client...
}

if (Meteor.isServer) {
   // Code running on server...
}

Kodu, yalnızca uygulama Cordova paketlemeyi kullanırken çalışacak şekilde sınırlayabilirsiniz.

if (Meteor.isCordova) {
   // Code running on Cordova...
}

Bazı eklentilerin sunucu ve DOM hazır olana kadar beklemesi gerekir. Her şey başlayana kadar beklemek için aşağıdaki kodu kullanabilirsiniz.

Meteor.startup(function () {
   // Code running after platform is ready...
});

Aşağıdaki tablo diğer bazı temel API yöntemlerini listeler.

Sr.No. Yöntem ve Ayrıntılar
1

Meteor.wrapAsync(function)

Eşzamansız kodu sarmak ve eşzamanlı hale dönüştürmek için kullanılır.

2

Meteor.absoluteUrl([path], [options])

Uygulamaya işaret eden mutlak URL oluşturmak için kullanılır.

3

Meteor.settings

Dağıtım yapılandırmasını ayarlamak için kullanılır.

4

Meteor.publish(name, function)

Kayıtları müşteriye yayınlamak için kullanılır.

Kontrol yöntemi, bağımsız değişken veya türlerin modelle eşleşip eşleşmediğini bulmak için kullanılır.

Kontrol Paketinin Yüklenmesi

Komut istemi penceresini açın ve paketi kurun.

C:\Users\username\Desktop\meteorApp>meteor add check

Çek kullanma

Aşağıdaki örnekte, kontrol etmek istiyoruz myValuebir dizedir. Doğru olduğu için uygulama hatasız ilerleyecektir.

meteorApp.js

var myValue = 'My Value...';
check(myValue, String);

Bu örnekte, myValue dize değil sayıdır, dolayısıyla konsol bir hata kaydedecektir.

meteorApp.js

var myValue = 1;
check(myValue, String);

Eşleşme Testi

Match.test kontrole benzer, fark, bir konsol hatası yerine test başarısız olduğunda, bir valuesunucuyu bozmadan. Aşağıdaki örnek, bir nesnenin birden çok anahtarla nasıl test edileceğini gösterir.

meteorApp.js

var myObject = {
   key1 : "Value 1...",
   key2 : "Value 2..."
}

var myTest = Match.test(myObject, {
   key1: String,
   key2: String
});

if ( myTest ) {
   console.log("Test is TRUE...");
} else {
   console.log("Test is FALSE...");
}

Her iki anahtar da dize olduğu için test true. Konsol ilk seçeneği günlüğe kaydedecektir.

Eğer değiştirirsek key2 numaralandırılırsa, test başarısız olur ve konsol ikinci seçeneği günlüğe kaydeder.

meteorApp.js

var myObject = {
   key1 : "Value 1...",
   key2 : 1
}

var myValue = 1;

var myTest = Match.test(myObject, {
   key1: String,
   key2: String
});

if ( myTest ) {
   console.log("Test is TRUE...");
} else {
   console.log("Test is FALSE...");
}

Blaze, canlı reaktif şablonlar oluşturmak için bir Meteor paketidir.

Oluşturma Yöntemi

Bu yöntem, şablonları DOM'a işlemek için kullanılır. İlk önce yaratacağızmyNewTemplatebu işlenecek. Ayrıca ekleyeceğizmyContainer, üst öğe olarak kullanılacak olan render yöntem, şablonumuzu nerede oluşturacağını bilir.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div id = "myContainer">
   </div>
</body>

<template name = "myNewTemplate">
   <p>Text from my new template...</p>
</template>

Daha sonra, iki argüman alacak bir render fonksiyonu oluşturacağız. Birincisi, render edilecek bir şablondur ve ikincisi, yukarıda bahsettiğimiz bir ana unsurdur.

meteorApp.js

Meteor.startup(function () {

   if(Meteor.isClient) {
      var myNewTemplate = Template.myNewTemplate;
      var myContainer = document.getElementById('myContainer');
      Blaze.render(myNewTemplate, myContainer);
   }
});

Verilerle Oluştur

Bazı verileri reaktif bir şekilde iletmeniz gerekirse, renderWithDatayöntem. HTML, önceki örnekteki ile tamamen aynı olacaktır.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div id = "myContainer">
   </div>
</body>

<template name = "myNewTemplate">
   <p>Text from my new template...</p>
</template>

Verilerimizi ikinci argüman olarak ekleyebiliriz. Meteor.renderWithDatayöntem. Diğer iki argüman önceki örnekteki ile aynıdır. Bu örnekte, verilerimiz bazı metinleri günlüğe kaydedecek bir işlevdir.

meteorApp.js

Meteor.startup(function () {

   if(Meteor.isClient) {
      var myNewTemplate = Template.myNewTemplate;
		
      var myData = function() {
         console.log('Log from the data object...')
      }

      var myContainer = document.getElementById('myContainer');
      Blaze.renderWithData(myNewTemplate, myData, myContainer);
   }
});

Yöntemi Kaldır

Ekleyebiliriz remove yöntem.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div id = "myContainer">
   </div>
</body>

<template name = "myNewTemplate">
   <p>Text from my new template...</p>
</template>

Bu örnekte, üç saniye sonra kaldırılacak şablonu işliyoruz. Dikkat edinBlaze.Remove şablonu kaldırmak için kullandığımız yöntem.

meteorApp.js

Meteor.startup(function () {

   if(Meteor.isClient) {
      var myNewTemplate = Template.myNewTemplate;
      var myContainer = document.getElementById('myContainer');
      var myRenderedTemplate = Blaze.render(myNewTemplate, myContainer);

      Meteor.setTimeout(function() {
         Blaze.remove(myRenderedTemplate);
      }, 3000);
   }
});

Aşağıdaki tablo, kullanılabilecek diğer yöntemleri göstermektedir.

Sr.No. Yöntem ve Ayrıntılar
1

Blaze.getData([elementOrView])

Oluşturma öğesinden veri almak için kullanılır.

2

Blaze.toHTML(templateOrView)

Dizeye şablonlar veya görünümler oluşturmak için kullanılır.

3

Blaze.toHTMLWithData(templateOrView, data)

Ek verilerle dizeye şablonlar veya görünümler oluşturmak için kullanılır.

4

new Blaze.View([name], renderFunction)

DOM'un yeni bir Blaze reaktif parçası oluşturmak için kullanılır.

5

Blaze.currentView

Mevcut görünümü almak için kullanılır.

6

Blaze.getView([element])

Mevcut görünümü almak için kullanılır.

7

Blaze.With(data, contentFunc)

İçeriğin bir kısmını bağlamla oluşturan bir görünüm oluşturmak için kullanılır.

8

Blaze.If(conditionFunc, contentFunc, [elseFunc])

Koşullu içerik oluşturan bir görünüm oluşturmak için kullanılır.

9

Blaze.Unless(conditionFunc, contentFunc, [elseFunc])

Bazı koşullu içeriği (ters çevrilmiş) oluşturan bir görünüm oluşturmak için kullanılır Blaze.if).

10

Blaze.Each(argFunc, contentFunc, [elseFunc])

İşleyen bir görünüm oluşturmak için kullanılır contentFunct her öğe için.

11

new Blaze.Template([viewName], renderFunction)

Ad ve içerikle yeni bir Blaze görünümü oluşturmak için kullanılır.

12

Blaze.isTemplate(value)

Değer bir şablon nesnesiyse true döndürmek için kullanılır.

Meteor kendi sunuyor setTimeout ve setIntervalyöntemler. Bu yöntemler, tüm global değişkenlerin doğru değerlere sahip olduğundan emin olmak için kullanılır. Normal JavaScript gibi çalışırlarsetTimout ve setInterval.

Zaman aşımı

Bu Meteor.setTimeout misal.

Meteor.setTimeout(function() {
   console.log("Timeout called after three seconds...");
}, 3000);

Konsolda, uygulama başladıktan sonra zaman aşımı işlevinin çağrıldığını görebiliriz.

Aralık

Aşağıdaki örnek, bir aralığın nasıl ayarlanacağını ve silineceğini gösterir.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   <div>
      {{> myTemplate}}
   </div>
</body>
 
<template name = "myTemplate">
   <button>CLEAR</button>
</template>

Başlangıcı ayarlayacağız counter her aralık çağrısından sonra güncellenecek değişken.

meteorApp.js

if (Meteor.isClient) {

   var counter = 0;

   var myInterval = Meteor.setInterval(function() {
      counter ++
      console.log("Interval called " + counter + " times...");
   }, 3000);

   Template.myTemplate.events({

      'click button': function() {
         Meteor.clearInterval(myInterval);
         console.log('Interval cleared...')
      }
   });
}

Konsol, güncellenen counterher üç saniyede bir değişken. Bunu tıklayarak durdurabilirizCLEARbuton. Bu arayacakclearInterval yöntem.

EJSON, JSON sözdiziminin bir uzantısıdır. Date ve Binary türleri.

EJSON'u yükleyin

EJSON paketini kurmak için komut istemi penceresinden eklememiz gerekiyor.

C:\Users\username\Desktop\meteorApp>meteor add ejson

Tarih Örneği

Seri durumdan çıkarabiliriz date kullanmak parse yöntem.

if (Meteor.isClient) {
   var myEjsonDate = '{"$date": 1455029631493}';
   var myDate = EJSON.parse(myEjsonDate);
   console.log(myDate);
}

Konsol, doğru tarih değerini kaydedecektir.

İkili Örnek

Aynısı ikili türlere de uygulanabilir.

if (Meteor.isClient) {
   var myEjsonBinary = '{"$binary": "c3VyZS4="}';
   var myBinary = EJSON.parse(myEjsonBinary);
   console.log(myBinary);
}

Konsolun yeni serileştirilmemiş değeri günlüğe kaydettiğini görebilirsiniz.

Stringify

Kullanarak bir nesneyi seri hale getirebiliriz stringifyyöntem. Bu, yukarıdaki örnekten tersine çevrilmiş işlemdir.

if (Meteor.isClient) {

   var myObject = {
      myDate : new Date(),
      myBinary : new Uint8Array([115, 117, 114, 101, 46])
   }

   var myEjosnData = EJSON.stringify(myObject);
   console.log(myEjosnData);
}

Yeni değerlerimizi konsolda görebiliriz.

Sr.No. Yöntem ve Ayrıntılar
1

EJSON.parse(string)

Bir dizeyi EJSON değerine ayrıştırmak için kullanılır.

2

EJSON.stringify(value)

Dizeye bir değer serileştirmek için kullanılır.

3

EJSON.fromJSONValue(value)

JSON'dan bir EJSON değerinin serisini kaldırmak için kullanılır.

4

EJSON.toJSONValue(value)

Bir EJSON değerini JSON'a serileştirmek için kullanılır.

5

EJSON.equals(value1, value2)

İki değerin eşit olup olmadığını karşılaştırmak için kullanılır.

6

EJSON.clone(value)

Değerin derin bir kopyasını döndürmek için kullanılır.

7

EJSON.newBinary

EJSON'un serileştirebileceği bir ikili veriyi atamak için kullanılır.

8

EJSON.isBinary(x)

Değerin ikili veri olup olmadığını kontrol etmek için kullanılır.

9

EJSON.addType(name, factory)

Özel bir EJSON türü oluşturmak için kullanılır.

10

customType.typeName()

Özel türün bir adını döndürmek için kullanılır.

11

customType.toJSONValue()

Özel türleri serileştirmek için kullanılır.

12

customType.clone()

Özel türün derin bir kopyasını döndürmek için kullanılır.

13

customType.equals(otherValue)

Özel tür değeri ile diğer değer arasında karşılaştırma yapmak için kullanılır.

Bu paket, HTTP istek API'sini sağlar get, post, put ve delete yöntemler.

Kurulum paketi

Bu paketi komut istemi penceresinde aşağıdaki kodu çalıştırarak kuracağız.

C:\Users\username\Desktop\meteorApp>meteor add http

ÇAĞRI Yöntemi

Bu, kullanabilen evrensel bir yöntemdir GET, POST, PUT ve DELETEargümanlar. Aşağıdaki örnek, nasıl kullanılacağını gösterirGETargüman. Bu bölümdeki örnekler, bu web sitesinden sahte REST API kullanacaktır .

Bu yöntemin dört bağımsız değişken kullandığını görebilirsiniz. İlk argümandan daha önce bahsetmiştikGET. İkincisi, API URL'sidir. Üçüncü argüman, bazı isteğe bağlı parametreleri ayarlayabileceğimiz boş bir nesnedir. Son yöntem, hataları işleyebileceğimiz ve bir yanıtla çalışabileceğimiz zaman uyumsuz bir geri aramadır.

HTTP.call( 'GET', 'http://jsonplaceholder.typicode.com/posts/1', {},
   function( error, response ) {

   if (error) {
      console.log(error);
   } else {
      console.log(response);
   }
});

GET Yöntemi

Aynı istek kullanılarak gönderilebilir GET onun yerine CALLyöntem. Şimdi ilk argümanın API URL'si olduğunu görebilirsiniz.

HTTP.get('http://jsonplaceholder.typicode.com/posts/1', {}, function( error, response ) {

   if ( error ) {
      console.log( error );
   } else {
      console.log( response );
   }
});

Önceki örneklerin her ikisi de aynı çıktıyı günlüğe kaydedecektir.

POST Yöntemi

Bu yöntemde sunucuya gönderilmesi gereken verileri ayarlıyoruz (postData) ikinci argüman olarak. Diğer her şey bizimkiyle aynıGET istek.

var postData = {

   data: {
      "name1": "Value1",
      "name2": "Value2",
   }
}

HTTP.post( 'http://jsonplaceholder.typicode.com/posts', postData, 
   function( error, response ) {

   if ( error ) {
      console.log( error );
   } else {
      console.log( response);
   }
});

Konsol bizim postData nesne.

PUT Yöntemi

Verilerimizi güncelleyebiliriz. PUTyöntem. Konsept, son örneğimizle aynı.

var updateData = {

   data: {
      "updatedName1": "updatedValue1",
      "UpdatedName2": "updatedValue2",
   }
}

HTTP.put( 'http://jsonplaceholder.typicode.com/posts/1', updateData, 
   function( error, response ) {
	
   if ( error ) {
      console.log( error );
   } else {
      console.log( response );
   }
});

Şimdi güncellenmiş nesnemizi konsolda görebiliriz.

DEL Yöntemi

Bunu kullanarak sunucuya bir silme isteği gönderebiliriz. DELyöntem. İçindeki her şeyi sileceğizdata nesne.

var deleteData = {
   data: {}
}

HTTP.del( 'http://jsonplaceholder.typicode.com/posts/1', deleteData, 
   function( error, response ) {
	
   if ( error ) {
      console.log( error );
   } else {
      console.log( response );
   }
});

Konsol, silme işleminin başarılı olduğunu gösterecektir.

Bu paket, Meteor Uygulamasından bir e-posta göndermeniz gerektiğinde kullanılır.

Adım 1 - Paket Ekle

Komut istemi penceresini açın ve aşağıdaki komutu çalıştırın -

C:\Users\username\Desktop\meteorApp>meteor add email

Adım 2 - Mailgun Hesabı

Biz bir hesap oluşturmanız gerekir burada . Bu, Meteor uygulamaları için varsayılan e-posta sağlayıcısıdır.

Giriş yaptıktan sonra, Domains sekmesini tıklayın ve sandbox URL altında Domain Name. Bulabileceğimiz yeni bir sayfa açacakDefault SMTP Login ve Default Password. Oluşturmak için bu ikisine ihtiyacımız olacakMAIL_URL Çevre değişkeni.

Eposta gönder

Geçerli bir oluşturmak için MAIL_URL Mailgun kimlik bilgilerinizi yerine yerleştirin YOUR_DEFAULT_SMTP_LOGIN ve YOUR_DEFAULT_PASSWORD.

if (Meteor.isServer) {

   Meteor.startup( function() {
      process.env.MAIL_URL = 
         "smtp://YOUR_DEFAULT_SMTP_LOGIN:[email protected]:587";

      Email.send({
         to: "[email protected]",
         from: "[email protected]",
         subject: "Meteor Email",
         text: "The email content..."
      });
   });
}

Uygulamayı çalıştırdığınızda, e-posta adresinize gönderilecektir.

Statik sunucu varlıkları bir privateuygulamanın içindeki alt klasör. Aşağıdaki örnekte, basit bir JSON dosyasındaki verilerin nasıl kullanılacağını öğreneceğiz.

Adım 1 - Dosya ve Klasör Oluşturun

Bir oluşturalım private klasör ve my-json.jsonbu klasörün içindeki dosya. Bunu aşağıdaki komutu kullanarak yapacağız.command prompt pencere ancak manuel olarak da oluşturabilirsiniz.

C:\Users\username\Desktop\meteorApp>mkdir private

C:\Users\username\Desktop\meteorApp\private>touch my-json.json

Adım 2 - Metin Alın

Dosyamızdan veri okuyabilmek için kullanacağız Asssets.getTextyöntem. Unutmayın, bu sadece sunucu tarafından yapılabilir. JSON kullandığımız için onu ayrıştırmamız gerekiyor.

if (Meteor.isServer) {
   var myFile = JSON.parse(Assets.getText('my-json.json'));
   console.log(myFile.data.text)
}

Aşağıdakiler, komut istemi penceresindeki çıktı olacaktır.

Adım 3 - EJSON Dosyası Oluşturun

Bu dosyayı içinde oluşturacağız privateKlasör. Bu dosya ikili veriler içerecek"myBinary": {"$binary": "c3VyZS4="}

C:\Users\username\Desktop\meteorApp\private>touch my-ejson.ejson

Adım 4 - İkili Alın

EJSON dosyalarını okumak için, Assets.getBinary yöntem.

if (Meteor.isServer) {
   var myFile = Assets.getBinary('my-ejson.ejson');
   console.log(EJSON.stringify(myFile));
}

Komut istemi EJSON değerini günlüğe kaydedecektir.

Bu bölümde, uygulamamızı nasıl güvenli hale getireceğimizi ve bir uygulama geliştirirken nelere dikkat edilmesi gerektiğini öğreneceğiz.

Otomatik Yayınlama ve Otomatik Güvenlik

Autopublishveritabanındaki tüm verileri müşteriye otomatik olarak yayınlayan bir pakettir. Bu, üretim sırasında devre dışı bırakılması gereken bir rahatlıktır. Komut isteminden devre dışı bırakılabilir.

C:\Users\username\Desktop\meteorApp>meteor remove autopublish

Kullanarak bazı verileri müşteriye yayınlayabilirsiniz. Meteor.publish() ve Meteor.subscribe() Yayınla ve Abone Ol bölümünde ele alacağımız yöntemler.

InsecureMongoDB komutlarının geliştiricinin konsoluna yazılmasına izin veren bir pakettir, böylece uygulamanın her kullanıcısı veritabanına erişebilir. Paket, komut isteminde aşağıdaki komut çalıştırılarak kaldırılabilir.

C:\Users\username\Desktop\meteorApp>meteor remove insecure

İyi uygulama, uygulamanızı geliştirmeye başlar başlamaz her iki paketi de kaldırmaktır, böylece kodunuzu daha sonra değiştirmeniz ve güncellemeniz gerekmez.

Sunucu Tarafı Yöntemlerini Kullanın

Yöntemlerinizi her zaman sunucuda oluşturmalısınız. Bunu kullanarak yapabilirsinizMeteor.methods() sunucuda ve Meteor.call()istemcide. Bununla ilgili daha fazla bilgiyi Yöntemler bölümünde öğreneceğiz.

Ek Güvenlik

Uygulamanıza ek güvenlik katmanları eklemek istiyorsanız, aşağıdakiler gibi başka Meteor paketlerini kullanmayı düşünmelisiniz:

  • Tarayıcı Politikası , uygulamanıza yüklenmesi gereken harici kaynakları kontrol etmek için kullanılabilir.

  • Kontrol paketi, işlenmeden önce kullanıcı girdi türlerini kontrol etmek için kullanılabilir.

  • Denetim Argümanları Kontrolü , tüm parametrelerin işlenmeden önce doğru şekilde kontrol edilmesini sağlayacak bir pakettir. Bazı parametreleri kaçırdıysanız, bu paket sizi bilgilendirecektir.

  • Mylar paketleri bazı ek güvenlik katmanları ekleyebilir. Bu tür bir korumaya ihtiyacınız varsa kontrol edebilirsiniz.

Verileri veritabanından aldığımızda sıralayabiliriz. Aşağıdaki örnekte, oluşturacağızUsersToplamak. Kullanacağızsort argüman ({sort: {name: 1}}) toplama verilerini ada göre sıralamak için. Numara1artan sırayı ayarlamak için kullanılır. Azalan sırayı kullanmak istersek, kullanırdık-1 yerine.

Users = new Mongo.Collection('users');

Users.insert({
   name: 'James',
   email: '[email protected]',
   joined: new Date(2016, 2, 23)
});

Users.insert({
   name: 'John',
   email: '[email protected]',
   joined: new Date(2016, 2, 19)
});

Users.insert({
   name: 'Jennifer',
   email: '[email protected]',
   joined: new Date(2016, 6, 24)
});

var sortByName = Users.find({}, {sort: {name: 1}}).fetch();

var sortByEmail = Users.find({}, {sort: {email: 1}}).fetch();

var sortByJoined = Users.find({}, {sort: {joined: 1}}).fetch();

console.log(sortByName);
console.log(sortByEmail);
console.log(sortByJoined);

Verileri e-postayla aynı şekilde sıralayabiliriz.

Users = new Mongo.Collection('users');

Users.insert({
   name: 'James',
   email: '[email protected]',
   joined: new Date(2016, 2, 23)
});

Users.insert({
   name: 'John',
   email: '[email protected]',
   joined: new Date(2016, 2, 19)
});

Users.insert({
   name: 'Jennifer',
   email: '[email protected]',
   joined: new Date(2016, 6, 24)
});

var sortByEmail = Users.find({}, {sort: {email: 1}}).fetch();

console.log(sortByEmail);

Son olarak, katılım tarihine göre sıralayabiliriz.

Users = new Mongo.Collection('users');

Users.insert({
   name: 'James',
   email: '[email protected]',
   joined: new Date(2016, 2, 23)
});

Users.insert({
   name: 'John',
   email: '[email protected]',
   joined: new Date(2016, 2, 19)
});

Users.insert({
   name: 'Jennifer',
   email: '[email protected]',
   joined: new Date(2016, 6, 24)
});

var sortByJoined = Users.find({}, {sort: {joined: 1}}).fetch();

console.log(sortByJoined);

Bu paket, eksiksiz bir kullanıcı kimlik doğrulama işlevi sağlar. Komut istemi penceresinde aşağıdaki kodu çalıştırarak ekleyebilirsiniz.

C:\Users\username\Desktop\meteorApp>meteor add accounts-password

Kimlik Doğrulama Örneği

Bu örnek, temel kimlik doğrulamasını gösterecektir. Biz yaratacağızregister, login, ve homeşablonlar. Eğer varsacurrentUser (kullanıcı başarıyla kaydolduysa veya oturum açtıysa), homeşablon gösterilecektir. Eğer yoksacurrentUser, register ve login şablonlar görünür olacak.

meteorApp.html

<head>
   <title>meteorApp</title>
</head>
 
<body>
   {{#if currentUser}}
      {{> home}}
      {{else}}
      {{> register}}
      {{> login}}
   {{/if}}
</body>

<template name = "register">
   <h2>REGISTER:</h2>
   <form>
      <input type = "email" name = "registerEmail"><br>
      <input type = "password" name = "registerPassword"><br>
      <input type = "submit" value = "Register"><br>
   </form>
</template>

<template name = "login">
   <h2>LOGIN:</h2>
   <form>
      <input type = "email" name = "loginEmail"><br>
      <input type = "password" name="loginPassword"><br>
      <input type = "submit" value = "Login"><br>
   </form>
</template>

<template name = "home">
   <p>You're logged in.</p>
   <button class = "logout">Logout</button>
</template>

İlk önce, bir registerEtkinlik. Bu fonksiyon kayıt girişlerini okuyacak, yeni bir kullanıcı oluşturacak ve bunu veritabanında saklayacaktır.

İkinci olay login. Bu kez işlev, girişleri okuyacaktır.login şablon, e-posta ve şifre geçerliyse kullanıcı oturum açın veya değilse bir hata döndürür.

Ve nihayet logout olay, düğme tıklandığında kullanıcının oturumu kapatmak için kullanılacaktır.

meteorApp.js

if (Meteor.isClient) {

   Template.register.events({
      'submit form': function(event) {
         event.preventDefault();

         var registerData = {
            email: event.target.registerEmail.value,
            password: event.target.registerPassword.value
         }

         Accounts.createUser(registerData, function(error) {
         
            if (Meteor.user()) {
               console.log(Meteor.userId());
            } else {
               console.log("ERROR: " + error.reason);
            }
         });
      }
   });

   Template.login.events({
   
      'submit form': function(event) {
         event.preventDefault();
         var myEmail = event.target.loginEmail.value;
         var myPassword = event.target.loginPassword.value;
			
         Meteor.loginWithPassword(myEmail, myPassword, function(error) {

            if (Meteor.user()) {
               console.log(Meteor.userId());
            } else {
               console.log("ERROR: " + error.reason);
            }
         });
      }
   });

   Template.home.events({

      'click .logout': function(event) {
         event.preventDefault();
			
         Meteor.logout(function(error) {

            if(error) {
               console.log("ERROR: " + error.reason);
            }
         });
      }
   });
}

Uygulama başladığında, aşağıdaki sayfayı alacağız.

E-posta ve şifreyi girildiğinde registerform, yeni kullanıcıyı kayıt edebilir ve giriş yapabiliriz. Konsolun kullanıcıları günlüğe kaydettiğini göreceğizid ve home şablon oluşturuldu.

loginE-posta ve şifre doğruysa olay veritabanını kontrol edecek ve kullanıcı oturum açacaktır. Değilse, konsol bir hata kaydedecektir.

Kullanıcı tıklarsa LOGOUT düğmesi, uygulama kullanıcının oturumunu kapatır ve register ve login şablonlar.

Meteor yöntemleri, sunucu tarafında yazılan, ancak istemci tarafından çağrılabilen işlevlerdir.

Sunucu tarafında iki basit yöntem oluşturacağız. Birincisi bizim argümanımıza 5 ekleyecek, ikincisi ise10.

Yöntemleri Kullanma

meteorApp.js

if(Meteor.isServer) {

   Meteor.methods({

      method1: function (arg) {
         var result = arg + 5;
         return result;
      },

      method2: function (arg) {
         var result = arg + 10;
         return result;
      }
   });
}

if(Meteor.isClient) {
   var aaa = 'aaa'
   Meteor.call('method1', aaa, function (error, result) {
	
      if (error) {
         console.log(error);
         else {
            console.log('Method 1 result is: ' + result);
         }
      }
   );

   Meteor.call('method2', 5, function (error, result) {

      if (error) {
         console.log(error);
      } else {
         console.log('Method 2 result is: ' + result);
      }
   });
}

Uygulamayı başlattıktan sonra hesaplanan değerleri konsolda göreceğiz.

Hataları Yönetme

Hataları ele almak için, Meteor.Erroryöntem. Aşağıdaki örnek, oturum açmamış kullanıcılar için hatanın nasıl işleneceğini gösterir.

if(Meteor.isServer) {

   Meteor.methods({

      method1: function (param) {

         if (! this.userId) {
            throw new Meteor.Error("logged-out",
               "The user must be logged in to post a comment.");
         }
         return result;
      }
   });
}

if(Meteor.isClient) {  Meteor.call('method1', 1, function (error, result) {

   if (error && error.error === "logged-out") {
      console.log("errorMessage:", "Please log in to post a comment.");
   } else {
      console.log('Method 1 result is: ' + result);
   }});

}

Konsol, özelleştirilmiş hata mesajımızı gösterecektir.

Bu bölümde kendi meteor paketimizi nasıl oluşturacağımızı öğreneceğiz.

Bir Paket Oluşturmak

Paketin oluşturulacağı masaüstüne yeni bir klasör ekleyelim. Komut istemi penceresini kullanacağız.

C:\Users\username\Desktop\meteorApp> mkdir packages

Şimdi yukarıda oluşturduğumuz klasörde paketi oluşturabiliriz. Komut isteminden aşağıdaki komutu çalıştırın.Username Meteor Geliştirici kullanıcı adıdır ve package-name paketin adıdır.

C:\Users\username\Desktop\meteorApp\packages>meteor create --package username:package-name

Paket Ekleme

Uygulamamıza yerel bir paket ekleyebilmek için, ENVIRONMENT VARIABLEbu Meteor'a paketi yerel klasörden yüklemesini söyleyecektir. Bilgisayar simgesine sağ tıklayın veproperties/Advanced system settings/Environment Variables/NEW.

Variable Name olmalı PACKAGE_DIRS. Variable Valueoluşturduğumuz klasörün yolu olmalıdır. Bizim durumumuzda,C:\Users\username\Desktop\meteorApp\packages.

Yeniden başlatmayı unutmayın command prompt yeni bir Ortam Değişkeni ekledikten sonra.

Şimdi aşağıdaki kodu çalıştırarak paketi uygulamamıza ekleyebiliriz -

C:\Users\username\Desktop\meteorApp>meteor add username:package-name

Paket Dosyaları

Oluşturduğumuz pakette aşağıdaki dört dosya bulunacaktır.

  • package-name-test.js
  • package-name.js
  • package.js
  • README.md

Test Paketi (paket adı-test.js)

Meteor teklifleri tinytesttest için paket. Önce komut istemi penceresinde aşağıdaki komutu kullanarak kuralım.

C:\Users\username\Desktop\meteorApp>meteor add tinytest

Eğer açarsak package-name-test.jsvarsayılan test örneğini göreceğiz. Uygulamayı test etmek için bu örneği kullanacağız. Not: Meteor paketleri geliştirirken kendi testlerimizi yazmak her zaman daha iyidir.

Paketi test etmek için, bu kodu komut isteminde çalıştıralım.

C:\Users\username\Desktop>meteor test-packages packages/package-name

Aşağıdaki sonucu alacağız.

package.js Dosyası

Kodu yazabileceğimiz dosya budur. Paketimiz için bazı basit işlevler oluşturalım. Paketimiz konsolda bazı metinler kaydedecektir.

package / package.js

myPackageFunction = function() {
   console.log('This is simple package...');
}

package-name.js Dosyası

Bu, bazı paket yapılandırmalarını ayarlayabileceğimiz dosyadır. Daha sonra geri döneceğiz, ancak şimdilik ihracat yapmamız gerekiyormyPackageFunctionböylece onu uygulamamızda kullanabiliriz. Bunu içeriye eklemeliyizPackage.onUseişlevi. Dosya böyle bir şeye benzeyecek.

paketler / paket-adı.js

Package.describe({
   name: 'username:package-name',
   version: '0.0.1',
   
   // Brief, one-line summary of the package.
   summary: '',
   
   // URL to the Git repository containing the source code for this package.
   git: '',
   
   // By default, Meteor will default to using README.md for documentation.
   
   // To avoid submitting documentation, set this field to null.
   documentation: 'README.md'
});

Package.onUse(function(api) {
   api.versionsFrom('1.2.1');
   api.use('ecmascript');
   api.addFiles('mypackage.js');
   api.export('myPackageFunction'); // We are exporting the function we created above...
});

Package.onTest(function(api) {
   api.use('ecmascript');
   api.use('tinytest');
   api.use('username:package-name');
   api.addFiles('package-name-tests.js');
});

Bir Paketin Kullanılması

Şimdi nihayet arayabiliriz myPackageFunction() bizim meteorApp.js dosya.

package / package.js

if(Meteor.isClient) {
   myPackageFunction();
}

Konsol, paketimizdeki metni günlüğe kaydedecektir.

Daha iyi anlamak için package.js dosya yapılandırılabilir, Meteor resmi belgelerinden örneği kullanacağız.

Bu örnek bir dosyadır ...

/* Information about this package */
Package.describe({
   
   // Short two-sentence summary.
   summary: "What this does",

   // Version number.
   version: "1.0.0",

   // Optional.  Default is package directory name.
   name: "username:package-name",

   // Optional github URL to your source repository.
   git: "https://github.com/something/something.git",
});

/* This defines your actual package */
Package.onUse(function (api) {

   // If no version is specified for an 'api.use' dependency, use the
   // one defined in Meteor 0.9.0.
   api.versionsFrom('0.9.0');

   // Use Underscore package, but only on the server.
   // Version not specified, so it will be as of Meteor 0.9.0.
   api.use('underscore', 'server');

   // Use iron:router package, version 1.0.0 or newer.
   api.use('iron:[email protected]');

   // Give users of this package access to the Templating package.
   api.imply('templating')

   // Export the object 'Email' to packages or apps that use this package.
   api.export('Email', 'server');

   // Specify the source code for the package.
   api.addFiles('email.js', 'server');
});

/* This defines the tests for the package */
Package.onTest(function (api) {

   // Sets up a dependency on this package
   api.use('username:package-name');

   // Allows you to use the 'tinytest' framework
   api.use('[email protected]');

   // Specify the source code for the package tests
   api.addFiles('email_tests.js', 'server');
});

/* This lets you use npm packages in your package*/
Npm.depends({
   simplesmtp: "0.3.10",
   "stream-buffers": "0.2.5"
});

Koleksiyonlar bölümünde daha önce tartışıldığı gibi, tüm verilerimiz müşteri tarafında mevcuttur. Bu, yayınlama ve abone olma yöntemleriyle çözülebilen bir güvenlik sorunudur.

Otomatik Yayını Kaldırma

Bu örnekte kullanacağız PlayersCollectionaşağıdaki verilerle toplama. Bu koleksiyonu daha önce bölüme konsantre olabilmek için hazırladık. Meteor uygulamasında MongoDB koleksiyonlarını nasıl oluşturacağınızdan emin değilseniz, koleksiyonlar bölümümüze bakın.

Verilerimizi korumak için kaldırmamız gerekiyor autopublish verileri istemci tarafında kullanmamıza izin veren paket.

C:\Users\username\Desktop\meteorApp>meteor remove autopublish

Bu adımdan sonra veritabanı verilerini istemci tarafından alamayacağız. Bunu yalnızca komut istemi penceresinde sunucu tarafından görebileceğiz. Aşağıdaki kodu kontrol edin -

meteorApp.js

var PlayersCollection = new Mongo.Collection('playersCollection');
var myLog = PlayersCollection.find().fetch();
console.log(myLog);

command prompt penceresi, koleksiyonun tamamını dört nesne ile gösterirken, developers consoleboş bir dizi gösterecektir. Artık uygulamamız daha güvenli.

Yayınla ve Abone Ol'u Kullanma

Diyelim ki müşterilerin verilerimizi kullanmasına izin vermek istiyoruz. Bunun için yaratmamız gerekiyorMeteor.publish()sunucuda yöntem. Bu yöntem, verileri müşteriye gönderecektir.

Bu verileri müşteri tarafında alabilmek ve kullanabilmek için, Meteor.subscribe()yöntem. Örneğin sonunda veritabanını araştırıyoruz. Bu kod hem istemci hem de sunucu tarafında çalışıyor.

var PlayersCollection = new Mongo.Collection('playersCollection');

if(Meteor.isServer) {

   Meteor.publish('allowedData', function() {
      return PlayersCollection.find();
   })
}

if (Meteor.isClient) {
   Meteor.subscribe('allowedData');
};

Meteor.setTimeout(function() {
   var myLog = PlayersCollection.find().fetch();
   console.log(myLog);
}, 1000);

Verilerimizin hem developers console ve command prompt pencere.

Müşteri Verilerini Filtreleme

Verilerin bir kısmını da yayınlayabiliriz. Bu örnekte, verileri şu şekilde yayınlıyoruz:name = "John".

var PlayersCollection = new Mongo.Collection('playersCollection');

if(Meteor.isServer) {

   Meteor.publish('allowedData', function() {
      return PlayersCollection.find({name: "John"});
   })
}

if (Meteor.isClient) {
   Meteor.subscribe('allowedData');
};

Meteor.setTimeout(function() {
   myLog = PlayersCollection.find().fetch();
   console.log(myLog);
}, 1000);

Bu kodu çalıştırdığımızda, command prompt tüm verileri günlüğe kaydedecek, istemci tarafı ise console sadece adı ile iki nesneyi günlüğe kaydedecek John.

Meteor, geliştiricilerin uygulamalarını yapılandırmalarına yardımcı olabilecek bazı özel klasörler sunar.

müşteri

Eğer bir clientklasör, bu klasörün içindeki her şey istemci tarafında çalıştırılacaktır. Bu, yerleştirebileceğiniz klasördür.HTML, CSSve müşteri tarafı JavaScript. YerleştirmelisinMeteor.subscribe fonksiyonlar, templates, helpers, ve eventsbu klasörün içinde. Not, çalıştırmanız gerekmezMeteor.isClient içine yerleştirilen dosyalardaki işlev client Klasör.

sunucu

Bu klasördeki dosyalar yalnızca server side. Burası yermethods, Meteor.Publish()işlevler ve diğer hassas veriler tutulmalıdır. Tüm kimlik doğrulama verileri burada tutulmalıdır. Kullanmana gerek yokMeteor.isServer() Bu klasördeki dosyalar için.

halka açık

Bu, görüntülerinizi, favicon'larınızı ve müşteriye sunulan diğer tüm verileri yerleştirmeniz gereken yerdir.

özel

Bu klasördeki dosyalara yalnızca sunucudan erişilebilir. Müşteriden gizlenecekler. KoyabilirsinJSON veya EJSON Bu klasörün içinde yalnızca sunucunun kullanacağı dosyalar.

istemci / uyumluluk

Bazı JavaScript kitaplıkları, değişkenleri global olarak dışa aktarır. Yeni bir değişken kapsamına alınmadan yürütülmesi gereken dosyalar için bu klasörü kullanın.

Geri kalan

Klasörlerin geri kalanı istediğiniz şekilde yapılandırılabilir. Yukarıda belirtilen klasörlerin dışına yerleştirilen kod,client ve serveryan. Burası modellerinizi tanımlayabileceğiniz iyi bir yer.

Yükleme Sırası

Dosyaların yükleme sırasını bilmek her zaman iyidir. Aşağıdaki liste Meteor Resmi Belgelerinden alınmıştır.

  • HTML şablon dosyaları her şeyden önce her zaman yüklenir

  • İle başlayan dosyalar main. en son yüklenir

  • Herhangi birinin içindeki dosyalar lib/ sonra dizin yüklenir

  • Daha derin yollara sahip dosyalar daha sonra yüklenir

  • Dosyalar daha sonra tüm yolun alfabetik sırasına göre yüklenir

Meteor ile ilgili harika şeylerden biri, uygulamayı dağıtmanın ne kadar kolay olmasıdır. Uygulamanız tamamlandıktan sonra, onu dünyayla paylaşmanın kolay bir yolu var. Tek yapmanız gereken, komut istemi penceresinde aşağıdaki kodu çalıştırmaktır.

C:\Users\username\Desktop\meteorApp>meteor deploy my-first-app-ever.meteor.com

Meteor geliştiriciler hesabına girmeniz istenecek username ve password.

Artık, uygulamanızın adını içeren aşağıdaki bağlantı üzerinden uygulamaya tarayıcıdan erişebileceksiniz.

http://my-first-app-ever.meteor.com/

Bu bölümde, uygulamanın bir android cihazda nasıl çalıştırılacağını öğreneceğiz. Meteor, kısa bir süre önce bu işlevi Windows işletim sistemi için ekledi, bu nedenle meteor uygulamamızı 1.3 beta sürümüne güncellememiz gerekecek.

Note- Bu öğreticiyi yazarken, Meteor'un 1.3 sürümü Beta sürümündedir. Üretim sürümü yayınlandığında bunu güncelleyeceğiz.

En yeni Meteor versiyonunu kullanmak istediğimiz için komut istemi penceresinde aşağıdaki kodu çalıştırarak güncelleyebiliriz.

C:\Users\username\Desktop\meteorApp>meteor update --release 1.3-beta.11

Adım 1 - Android SDK'yı yükleyin

Android SDK'yı yüklemek için aşağıdaki tablodaki bağlantıyı kullanın.

Sr.No. Yazılım ve Açıklama
1

Java Development Kit & Android SDK

Meteor uygulamalarını mobil ortamda çalıştırabilmek için Android SDK'ya ihtiyacınız olacak. Yüklemediyseniz, Android Ortam Kurulumu eğitimimize göz atabilirsiniz .

Adım 2 - Bir Android Platformu Ekleyin

Şimdi projemize bir Android platformu eklememiz gerekiyor.

C:\Users\username\Desktop\meteorApp>meteor add-platform android

Adım 3 - Uygulamayı bir Android Emulator'da çalıştırın

Uygulamayı bir Android öykünücüsü üzerinde çalıştırmak için, –verbose Başlatma işlemi sırasında olası hataları tanımlayabilmek için satırın sonundaki komutu.

C:\Users\username\Desktop\meteorApp>meteor run android --verbose

Uygulamayı bir Android Cihazda Çalıştırın

Android emülatörleri yavaş olduğundan, uygulamanızı doğrudan cihazınızda çalıştırmak her zaman daha iyi bir seçenektir. Cihazı bilgisayarınıza bağlayarak, geliştiricilerin modunu ve USB hata ayıklamasını etkinleştirerek yapabilirsiniz.

Bu işlem, belirli cihazlar için farklıdır. Bulman gerekBuild Number içinde settings/Aboutve yedi kez dokunun. Geliştirici olduğunuzu belirten bir bildirim alacaksınız veDeveloper Options kilidi açılacak.

Ara settings tekrar ve etkinleştir USB debugging.

Meteor uygulamasını, komut isteminde aşağıdaki komutu kullanarak mobil cihazınızda çalıştırabilirsiniz.

C:\Users\username\Desktop\meteorApp>meteor run android-device

Bu bölümde, basit bir yapılacaklar uygulaması oluşturmayı öğreneceğiz.

Adım 1 - Bir Uygulama Oluşturun

Komut istemini açın ve aşağıdaki komutu çalıştırın -

C:\Users\username\Desktop>meteor create todo-app

Uygulamayı görmek için, uygulamayı şununla çalıştırmanız gerekir: meteor komuta et ve git http://localhost:3000

C:\Users\username\Desktop\todo-app>meteor

Adım 2 - Klasör ve Dosya Oluşturun

Varsayılan dosya yapısı yerine onu yeniden düzenleyeceğiz. Bir oluşturalımclient oluşturacağımız klasör todo-app.html, todo-app.css ve todo-app.js.

C:\Users\username\Desktop\todo-app>mkdir client
C:\Users\username\Desktop\todo-app\client>touch todo-app.html
C:\Users\username\Desktop\todo-app\client>touch todo-app.js

Ayrıca bir server klasör server.js içeride.

C:\Users\username\Desktop\todo-app>mkdir server
C:\Users\username\Desktop\todo-app\server>touch server.js

Son olarak, oluşturalım collections klasör task-collection.js dosya içinde.

C:\Users\username\Desktop\todo-app>mkdir server
C:\Users\username\Desktop\todo-app\collections>touch task-collection.js

Uygulama yapısını aşağıdaki görüntüde görebilirsiniz -

3. Adım - client / todo-app.html

İlk geliştirme adımımız, uygulama için HTML oluşturmaktır. Yeni görevler ekleyebileceğimiz bir giriş alanına ihtiyacımız var. Görevler bir liste şeklinde olacaktır.delete ve checkişlevsellik. Ayrıca tamamlanmış görevleri göstermek veya gizlemek için işlevlere sahip olacağız.

<head>
   <title>Todo App</title>
</head>

<body>
   <h1>Todo List ({{incompleteCount}})</h1>

   <label class = "hide-completed">
      <input type = "checkbox" checked = "{{hideCompleted}}" />
      Hide Completed Tasks
   </label>

   <form class = "new-task">
      <input type = "text" name = "text" placeholder = "Add new tasks" />
   </form>

   <ul>
      {{#each tasks}}
         {{> task}}
      {{/each}}
   </ul>
</body>

<template name = "task">
   <li class = "{{#if checked}}checked{{/if}}">
      <button class = "delete">x</button>
      <input type = "checkbox" checked = "{{checked}}" class = "toggle-checked" />
      <span>{{username}} - {{text}}</span>
   </li>
</template>

Adım 4 - collections / task-collection.js

Burası yeni bir MongoDB Koleksiyonu oluşturacağımız yer, böylece onu hem sunucu hem de istemci tarafında kullanabiliriz.

Tasks = new Mongo.Collection("tasks");

Adım 5 - server / server.js

Uygulamamız için sunucu tarafında yöntemler tanımlayacağız. Bu yöntemler müşteriden çağrılacaktır. Bu dosyada ayrıca veritabanı sorgusunu da yayınlayacağız.

// Publishing tasks from the server...

Meteor.publish("tasks", function () {
   return Tasks.find({});
});

// Methods for handling MongoDb Tasks collection data...

Meteor.methods({

   addTask: function (text) {

      Tasks.insert({
         text: text,
         createdAt: new Date(),
      });
   },

   deleteTask: function (taskId) {
      var task = Tasks.findOne(taskId);
      Tasks.remove(taskId);
   },

   setChecked: function (taskId, setChecked) {
      var task = Tasks.findOne(taskId);
      Tasks.update(taskId, { $set: { checked: setChecked} });
   }
});

Adım 6 - client / todo-app.js

Bu, ana istemci JavaScript dosyasıdır. Bu dosya da yeniden düzenlenebilir, ancak tüm istemci tarafı kodunu buraya yazacağız. İlk olarak, abone oluruztasksunucuda yayınlanan koleksiyon. Sonra yaratıyoruzhelpers uygulama mantığını işleyebilmek için ve son olarak, events bu, sunucudan yöntemleri çağıracaktır.

// Subscribing to the published tasks
Meteor.subscribe("tasks");

// Show/Hide functionality
Template.body.helpers({

   tasks: function () {

      if (Session.get("hideCompleted")) {

         // If hide completed is checked, filter tasks
         return Tasks.find({checked: {$ne: true}}, {sort: {createdAt: -1}}); } else { // Otherwise, return all of the tasks return Tasks.find({}, {sort: {createdAt: -1}}); } }, hideCompleted: function () { return Session.get("hideCompleted"); }, incompleteCount: function () { return Tasks.find({checked: {$ne: true}}).count();
   }
});

// Events for creating new tasks and Show/Hide functionality.
// Calling methods from the server

Template.body.events({

   "submit .new-task": function (event) {
      event.preventDefault();
      var text = event.target.text.value;

      Meteor.call("addTask", text);
      event.target.text.value = "";
   },

   "change .hide-completed input": function (event) {
      Session.set("hideCompleted", event.target.checked);
   }
});

// Events for Deleting and Check/Uncheck functionality
Template.task.events({
   
   "click .toggle-checked": function () {

      // Set the checked property to the opposite of its current value
      Meteor.call("setChecked", this._id, ! this.checked);
   },

   "click .delete": function () {
      Meteor.call("deleteTask", this._id);
   }
});

7. Adım - Dağıtın

Geliştirmeyi tamamladıktan sonra, uygulamayı komut istemi penceresinden dağıtabiliriz. Uygulamamızın dağıtım adımy-first-todo-app.

C:\Users\username\Desktop\todo-app>meteor deploy my-first-todo-app

Açabiliriz http://my-first-todo-app.meteor.com/ Uygulamamızı kullanmaya başlamak için.

Önceki bölümlerde Meteor geliştirmenin en iyi uygulamalarının bazılarını zaten ele almıştık. Meteor kullanırken akılda tutulması gereken en iyi uygulamalardan bazıları aşağıdadır.

Dizin Yapısı

Meteor uygulamalarında dizin yapısı hakkında katı kurallar yoktur. Yönergeler hakkında daha fazla bilgi için Meteor - Yapı bölümüne bakın.

Yöntemleri Kullan

Hassas verilerle çalışırken aramak yerine her zaman Meteor - Yöntemleri kullanmalısınızinsert, update, ve remove doğrudan müşteriden.

Veri yönetimi

Yayınlama ve Abone Olma yöntemlerini kullanarak verilerinizi koruyun . Verilerinizin tüm müşteriler tarafından kullanılabilir olmasını istiyorsanız, şunu kullanabilirsiniz:nullbunun yerine yayın adı olarak. Küçük veri yığınlarını yayınlamak, uygulamanın performansını da artıracaktır.

Verileri Doğrula

Koleksiyonda saklanacak tüm verileri doğrulamalısınız. En iyi seçeneklerden biri collection2 paketidir. Bu paket, sunucu ve istemci tarafı doğrulamasını ayarlamayı kolaylaştırır.

Oturumu Küçült

session değişkenler genel değişkenlerdir ve küresellerin kullanılması JavaScript'in en iyi uygulamalarına aykırıdır.

Yönlendirici

Meteor rotası için en popüler iki seçenek vardır. Daha küçük uygulamalar için Iron Router vardır . Veriler değiştiğinde otomatik olarak yeniden çalıştırılır. Daha büyük uygulamalar için Akış Yönlendiricisi vardır . Bu yönlendirici, biraz daha fazla standart kod pahasına şablonların yeniden oluşturulmasını optimize etmek için size daha fazla özgürlük sağlar.

Paketler

Uygulamanızın içinde kullanmayı seçmeden önce her zaman paketin düzenli olarak güncellenip güncellenmediğini kontrol edin.