उल्का - त्वरित गाइड
उल्का के आधिकारिक दस्तावेज के अनुसार -
उल्का आधुनिक वेब और मोबाइल एप्लिकेशन विकसित करने के लिए एक पूर्ण-स्टैक जावास्क्रिप्ट प्लेटफॉर्म है। उल्का में कनेक्टेड-क्लाइंट रिएक्टिव एप्लिकेशन, एक बिल्ड टूल, और नोड.जेएस और सामान्य जावास्क्रिप्ट समुदाय से पैकेजों का एक क्यूरेट सेट बनाने के लिए प्रौद्योगिकियों का एक प्रमुख सेट शामिल है।
विशेषताएं
Web and Mobile - उल्का वेब, एंड्रॉइड और आईओएस ऐप विकसित करने के लिए एक मंच प्रदान करता है।
Universal Apps - वेब ब्राउज़र और मोबाइल उपकरणों के लिए समान कोड।
Packages - उन पैकेजों की विशाल संख्या जो स्थापित करने और उपयोग करने में आसान हैं।
Meteor Galaxy - उल्का ऐप परिनियोजन के लिए क्लाउड सेवा।
लाभ
- डेवलपर्स को केवल सर्वर और क्लाइंट साइड डेवलपमेंट के लिए जावास्क्रिप्ट की आवश्यकता होती है।
- कोडिंग बहुत सरल और शुरुआती अनुकूल है।
- उल्का ऐप डिफ़ॉल्ट रूप से वास्तविक समय होते हैं।
- आधिकारिक और सामुदायिक पैकेज विशाल समय सेवर हैं।
सीमाओं
बड़े और जटिल अनुप्रयोगों के लिए उल्का बहुत उपयुक्त नहीं है।
Meteor के साथ काम करते समय बहुत सा जादू चल रहा है, इसलिए डेवलपर्स खुद को किसी तरह से सीमित पा सकते हैं।
इस अध्याय में, हम सीखेंगे कि विंडोज ऑपरेटिंग सिस्टम पर उल्का कैसे स्थापित करें। इससे पहले कि हम उल्का के साथ काम करना शुरू करें, हमें आवश्यकता होगीNodeJS। यदि आपके पास यह स्थापित नहीं है, तो आप नीचे दिए गए लिंक की जांच कर सकते हैं।
शर्त
NodeJS उल्का विकास के लिए आवश्यक मंच है। यदि आपके पास NodeJS पर्यावरण सेटअप तैयार नहीं है, तो आप हमारी जांच कर सकते हैंNodeJS Environment Setup।
उल्का स्थापित करें
इस पृष्ठ से आधिकारिक उल्का इंस्टॉलर डाउनलोड करें
यदि स्थापना के दौरान कोई त्रुटि होती है, तो इंस्टॉलर को व्यवस्थापक के रूप में चलाने का प्रयास करें। एक बार स्थापना पूर्ण हो जाने के बाद, आपको एक उल्का खाता बनाने के लिए कहा जाएगा।
जब आप उल्का इंस्टॉलर को स्थापित करना समाप्त करते हैं, तो आप कमांड प्रॉम्प्ट विंडो में निम्न कोड को चलाकर सब कुछ सही ढंग से स्थापित होने पर परीक्षण कर सकते हैं।
C:\Users\username>meteor
निम्नलिखित उत्पादन होगा -
इस अध्याय में, हम सीखेंगे कि आपका पहला उल्का एप्लिकेशन कैसे बनाया जाए।
स्टेप 1 - ऐप बनाएं
एप्लिकेशन बनाने के लिए, हम चलाएंगे meteor createकमांड प्रॉम्प्ट विंडो से कमांड। ऐप्स का नाम होगाmeteorApp।
C:\Users\username\Desktop\Meteor>meteor create meteorApp
स्टेप 2 - ऐप को रन करें
हम टाइप करके ऐप चला सकते हैं meteor आदेश।
C:\Users\username\Desktop\meteorApp>meteor
यह कमांड कई प्रक्रियाएं शुरू करेगी, जिन्हें निम्नलिखित छवि में देखा जा सकता है।
चरण 3 - परिणाम सत्यापित करें
अब, हम खोल सकते हैं http://localhost:3000/ यह देखने के लिए कि हमारा पहला उल्का ऐप कैसा दिखता है।
उल्का टेम्प्लेट तीन शीर्ष स्तर टैग का उपयोग कर रहे हैं। पहले दो हैंhead तथा body। ये टैग नियमित HTML में समान कार्य करते हैं। तीसरा टैग हैtemplate। यह वह स्थान है, जहाँ हम HTML को जावास्क्रिप्ट से जोड़ते हैं।
सरल टेम्पलेट
निम्नलिखित उदाहरण दिखाता है कि यह कैसे काम करता है। हम एक टेम्पलेट बना रहे हैंname = "myParagraph"विशेषता। हमारीtemplate टैग नीचे बनाया गया है bodyतत्व, हालांकि, हमें इसे स्क्रीन पर प्रस्तुत करने से पहले इसे शामिल करने की आवश्यकता है। हम इसका उपयोग करके कर सकते हैं{{> myParagraph}}वाक्य - विन्यास। हमारे टेम्पलेट में, हम डबल घुंघराले ब्रेसिज़ का उपयोग कर रहे हैं({{text}})। इसे उल्का टेम्प्लेट भाषा कहा जाता हैSpacebars।
हमारी जावास्क्रिप्ट फ़ाइल में, हम सेटिंग कर रहे हैं Template.myParagraph.helpers({})विधि जो हमारे टेम्पलेट के लिए हमारा कनेक्शन होगी। हम केवल उपयोग कर रहे हैंtext इस उदाहरण में सहायक।
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...'
});
}
हम परिवर्तनों को सहेजने के बाद, निम्नलिखित आउटपुट होंगे -
ब्लॉक टेम्पलेट
निम्नलिखित उदाहरण में, हम उपयोग कर रहे हैं {{#each paragraphs}} अधिक से अधिक करने के लिए paragraphs सरणी और वापसी टेम्पलेट name = "paragraph" प्रत्येक मूल्य के लिए।
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div>
{{#each paragraphs}}
{{> paragraph}}
{{/each}}
</div>
</body>
<template name = "paragraph">
<p>{{text}}</p>
</template>
हमें बनाने की जरूरत है paragraphsसहायक। यह पांच पाठ मानों के साथ एक सरणी होगी।
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..." }
]
});
}
अब, हम स्क्रीन पर पाँच पैराग्राफ देख सकते हैं।
इस अध्याय में, हम सीखेंगे कि कैसे उपयोग करना है MongoDB संग्रह।
एक संग्रह बनाएँ
हम निम्नलिखित कोड के साथ एक नया संग्रह बना सकते हैं -
meteorApp.js
MyCollection = new Mongo.Collection('myCollection');
डेटा जोड़ें
संग्रह बन जाने के बाद, हम डेटा का उपयोग करके जोड़ सकते हैं insert तरीका।
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);
डेटा का पता लगाएं
हम उपयोग कर सकते हैं find संग्रह में डेटा की खोज करने की विधि।
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);
कंसोल उस डेटा को दिखाएगा जो हमने पहले डाला था।
हम खोज मापदंडों को जोड़कर एक ही परिणाम प्राप्त कर सकते हैं।
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);
डेटा को अद्यतन करें
अगला कदम हमारे डेटा को अपडेट करना है। हमने एक संग्रह बनाया है और नया डेटा सम्मिलित करने के बाद, हम उपयोग कर सकते हैंupdate तरीका।
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);
कंसोल दिखाएगा कि हमारा संग्रह अपडेट किया गया है।
डेटा हटाएं
डेटा का उपयोग करके संग्रह से हटाया जा सकता है removeतरीका। हम सेट कर रहे हैंid विशिष्ट डेटा को हटाने के लिए एक पैरामीटर के रूप में इस उदाहरण में।
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);
कंसोल एक खाली सरणी दिखाएगा।
यदि हम संग्रह से सब कुछ हटाना चाहते हैं, तो हम उसी विधि का उपयोग कर सकते हैं, हालांकि, इसके बजाय id हम एक खाली वस्तु का उपयोग करेंगे {}। हमें सुरक्षा कारणों से सर्वर पर ऐसा करने की आवश्यकता है।
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);
}
हम अन्य मापदंडों का उपयोग करके डेटा को भी हटा सकते हैं। पिछले उदाहरण की तरह, Meteor हमें सर्वर से ऐसा करने के लिए मजबूर करेगा।
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);
}
यह देखा जा सकता है कि डेटा को कमांड विंडो से हटा दिया गया है।
इस अध्याय में, हम सीखेंगे कि उल्का रूपों के साथ कैसे काम किया जाए।
पाठ इनपुट
सबसे पहले, हम एक बनाएँगे form पाठ इनपुट फ़ील्ड और सबमिट बटन के साथ तत्व।
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>
जावास्क्रिप्ट फ़ाइल में, हम बनाएँगे submitप्रतिस्पर्धा। ब्राउज़र को ताज़ा करने से रोकने के लिए हमें डिफ़ॉल्ट ईवेंट व्यवहार को रोकने की आवश्यकता है। अगला, हम इनपुट फ़ील्ड की सामग्री लेने जा रहे हैं और इसे असाइन करते हैंtextValue चर।
निम्नलिखित उदाहरण में, हम केवल उस सामग्री को डेवलपर्स कंसोल में लॉग करेंगे। और आखिरी चीज जो हमें चाहिए वह है इनपुट क्षेत्र को साफ करना।
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 = "";
}
});
}
जब हम अपने इनपुट फ़ील्ड में "कुछ टेक्स्ट ..." टाइप करते हैं और इसे सबमिट करते हैं, तो कंसोल हमारे द्वारा दर्ज किए गए टेक्स्ट को लॉग करेगा।
रेडियो के बटन
रेडियो बटन के लिए एक समान अवधारणा का उपयोग किया जा सकता है।
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);
}
});
}
जब हम पहला बटन सबमिट करते हैं, तो कंसोल निम्न आउटपुट दिखाएगा।
चेक बॉक्स
निम्न उदाहरण दिखाता है कि चेकबॉक्स का उपयोग कैसे करें। आप देख सकते हैं कि हम उसी प्रक्रिया को दोहरा रहे हैं।
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);
}
});
}
फॉर्म सबमिट करने के बाद, चेक किए गए इनपुट को लॉग इन किया जाएगा true, जबकि अनियंत्रित एक के रूप में लॉग इन किया जाएगा false।
ड्रॉपडाउन का चयन करें
निम्नलिखित उदाहरण में, हम सीखेंगे कि कैसे उपयोग किया जाए selectतत्व। हम उपयोग करेंगेchange विकल्प बदलने पर हर बार डेटा अपडेट करने की घटना।
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);
}
});
}
यदि हम तीसरा विकल्प चुनते हैं, तो कंसोल विकल्प मान को लॉग करेगा।
इस अध्याय में, हम सीखेंगे कि कैसे उपयोग करना है tag, class तथा idईवेंट चयनकर्ता के रूप में। घटनाओं के साथ काम करना बहुत सीधा है।
HTML टेम्पलेट में तीन तत्व बनाते हैं। पहले वाला हैpदूसरा है myClass वर्ग और अंतिम एक है myId आईडी।
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>
हमारी जावास्क्रिप्ट फ़ाइल में, हम ऊपर बने तीन तत्वों के लिए तीन इवेंट सेट कर रहे हैं। आप देख सकते हैं कि हम सिर्फ जोड़ रहे हैंp, .myClass तथा #myId के बाद clickप्रतिस्पर्धा। ये हैंselectors हमने ऊपर उल्लेख किया है।
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...");
},
});
}
इसका परीक्षण करने के लिए, हम पहले क्लिक कर सकते हैं PARAGRAPH, फिर CLASS बटन और अंत में IDबटन। हमें निम्नलिखित कंसोल लॉग मिलेगा।
हम ऊपर दिए गए उदाहरण का अनुसरण करते हुए अन्य सभी जावास्क्रिप्ट घटनाओं - क्लिक, dbclick, Referencemenu, mousedown, mouseup, mouseover, mouseout, mousemove का उपयोग कर सकते हैं।
सत्र डेटा का उपयोग करने के लिए उपयोग किया जाता है जबकि उपयोगकर्ता ऐप का उपयोग कर रहे हैं। उपयोगकर्ता द्वारा ऐप छोड़ने पर यह डेटा हटा दिया जाएगा।
इस अध्याय में, हम सीखेंगे कि सत्र ऑब्जेक्ट कैसे सेट करें, कुछ डेटा स्टोर करें, और उस डेटा को वापस करें। हम मूल HTML सेटअप का उपयोग करेंगे।
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div>
{{> myTemplate}}
</div>
</body>
<template name = "myTemplate">
</template>
अब, हम स्टोर करेंगे myData स्थानीय रूप से उपयोग कर रहा है Session.set()तरीका। एक बार विधि सेट हो जाने पर, हम इसका उपयोग करके वापस कर सकते हैंSession.get() तरीका।
meteorApp.js
if (Meteor.isClient) {
var myData = {
key1: "value1",
key2: "value2"
}
Session.set('mySession', myData);
var sessionDataToLog = Session.get('mySession');
console.log(sessionDataToLog);
}
यदि हम कंसोल की जांच करते हैं, तो हम देखेंगे कि संग्रहीत डेटा लॉग किया गया है।
अगले अध्याय में, हम सीखेंगे कि सत्र चर का उपयोग करके ऑटो-अपडेट कैसे करें।
ट्रैकर एक छोटा पुस्तकालय है जिसका उपयोग ऑटो अपडेटिंग टेम्प्लेट के लिए किया जाता है, जब सत्र चर बदल गया है। इस अध्याय में, हम सीखेंगे कि ट्रैकर कैसे काम करता है।
सबसे पहले, हम एक बनाएँगे button जिसका उपयोग सत्र को अपडेट करने के लिए किया जाएगा।
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div>
{{> myTemplate}}
</div>
</body>
<template name = "myTemplate">
<button id = "myButton">CLICK ME</button>
</template>
अगला, हम शुरुआती सत्र मूल्य निर्धारित करेंगे myData और एक बनाएँ mySession वस्तु। Tracker.autorun विधि का उपयोग नज़र रखने के लिए किया जाता है mySession। जब भी यह ऑब्जेक्ट बदलता है, तो टेम्पलेट ऑटो-अपडेट होगा। इसे जांचने के लिए, हम अपडेट के लिए एक क्लिक ईवेंट सेट करेंगे।
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 ++);
}
});
}
अगर हम क्लिक करें CLICK ME बटन पांच बार, हम देखेंगे कि हर बार सत्र अपडेट होने पर ट्रैकर नए मानों को लॉग कर रहा है।
उल्का हजारों सामुदायिक पैकेज प्रदान करता है जिनका उपयोग आप अपने ऐप को विकसित करते समय कर सकते हैं।
पैकेज जोड़ना
आप यहां आधिकारिक उल्का पैकेज सर्वर की जांच कर सकते हैं । बस आपको जिस पैकेज की ज़रूरत है उसे खोजें और कमांड प्रॉम्प्ट विंडो में जोड़ें। यदि, उदाहरण के लिए, आप जोड़ना चाहते हैंhttp अपने ऐप के लिए पैकेज, आप इसे निम्न कोड चलाकर कर सकते हैं -
C:\Users\username\Desktop\meteorApp>meteor add http
संकुल हटाना
पैकेज निकालने के लिए एक समान सिद्धांत का उपयोग किया जा सकता है -
C:\Users\username\Desktop\meteorApp>meteor remove http
संकुल अद्यतन कर रहा है
आप निम्नलिखित कोड चलाने वाले पैकेज को अपडेट कर सकते हैं -
C:\Users\username\Desktop\meteorApp>meteor update http
वर्तमान संकुल की जाँच
आप यह भी देख सकते हैं कि आपका वर्तमान एप्लिकेशन किन पैकेजों का उपयोग कर रहा है।
C:\Users\username\Desktop\meteorApp>meteor list
पैकेज रखरखाव
अगर एक पैकेज है : नाम में, इसका मतलब है कि यह एक सामुदायिक पैकेज है, जबकि बिना उपसर्ग वाले उल्का विकास समूह द्वारा बनाए रखा जाता है।
उल्का विकास समूह पैकेज जोड़ना
C:\Users\username\Desktop\meteorApp>meteor add http
सामुदायिक पैकेज जोड़ना
C:\Users\username\Desktop\meteorApp>meteor add cfs:http-methods
यदि आप केवल सर्वर या क्लाइंट साइड पर चलने के लिए कोड को सीमित करना चाहते हैं, तो आप निम्न कोड का उपयोग कर सकते हैं -
meteorApp.js
if (Meteor.isClient) {
// Code running on client...
}
if (Meteor.isServer) {
// Code running on server...
}
आप कोड को केवल चलाने के लिए कोड को सीमित कर सकते हैं जब ऐप कॉर्डोवा बंडलिंग का उपयोग कर रहा हो।
if (Meteor.isCordova) {
// Code running on Cordova...
}
कुछ प्लगइन्स को सर्वर और DOM तैयार होने तक इंतजार करना होगा। सब कुछ शुरू होने तक प्रतीक्षा करने के लिए आप निम्न कोड का उपयोग कर सकते हैं।
Meteor.startup(function () {
// Code running after platform is ready...
});
निम्नलिखित तालिका कुछ अन्य मुख्य एपीआई तरीकों को सूचीबद्ध करती है।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | Meteor.wrapAsync(function) एसिंक्रोनस कोड को रैप करने के लिए उपयोग किया जाता है और इसे सिंक्रोनस में परिवर्तित किया जाता है। |
2 | Meteor.absoluteUrl([path], [options]) ऐप की ओर इशारा करते हुए निरपेक्ष URL बनाने के लिए उपयोग किया जाता है। |
3 | Meteor.settings परिनियोजन कॉन्फ़िगरेशन सेट करने के लिए उपयोग किया जाता है। |
4 | Meteor.publish(name, function) ग्राहक को रिकॉर्ड प्रकाशित करने के लिए उपयोग किया जाता है। |
चेक पद्धति का उपयोग यह पता लगाने के लिए किया जाता है कि क्या तर्क या प्रकार पैटर्न से मेल खा रहे हैं।
चेक पैकेज स्थापित करना
कमांड प्रॉम्प्ट विंडो खोलें और पैकेज स्थापित करें।
C:\Users\username\Desktop\meteorApp>meteor add check
चेक का उपयोग करना
निम्नलिखित उदाहरण में, हम जांचना चाहते हैं कि क्या myValueएक तार है। चूंकि यह सच है, ऐप बिना किसी त्रुटि के आगे बढ़ेगा।
meteorApp.js
var myValue = 'My Value...';
check(myValue, String);
इस उदाहरण में, myValue एक स्ट्रिंग नहीं बल्कि एक संख्या है, इसलिए कंसोल एक त्रुटि लॉग करेगा।
meteorApp.js
var myValue = 1;
check(myValue, String);
मैच टेस्ट
Match.test यह जांचने के समान है, कि जब कंसोल कंसोल की बजाय परीक्षा विफल हो जाती है, तब हमें अंतर मिलेगा valueसर्वर को तोड़े बिना। निम्न उदाहरण दिखाता है कि किसी ऑब्जेक्ट को कई कुंजियों के साथ कैसे परीक्षण किया जाए।
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...");
}
चूंकि दोनों कुंजियां तार हैं, परीक्षण है true। कंसोल पहले विकल्प को लॉग करेगा।
अगर हम बदलते हैं key2 नंबर पर, परीक्षण विफल हो जाएगा और कंसोल दूसरा विकल्प लॉग करेगा।
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...");
}
ब्लेज़ लाइव प्रतिक्रियाशील टेम्पलेट्स के निर्माण के लिए एक उल्का पैकेज है।
रेंडर विधि
इस विधि का उपयोग DOM में टेम्प्लेट को प्रस्तुत करने के लिए किया जाता है। पहले हम बनाएंगेmyNewTemplateइसका प्रतिपादन किया जाएगा। हम भी जोड़ देंगेmyContainer, जिसका उपयोग मूल तत्व के रूप में किया जाएगा, इसलिए render विधि जानता है कि हमारे टेम्पलेट को कहां प्रस्तुत करना है।
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div id = "myContainer">
</div>
</body>
<template name = "myNewTemplate">
<p>Text from my new template...</p>
</template>
अगला, हम एक रेंडर फ़ंक्शन बनाएंगे जो दो तर्क देगा। पहला एक टेम्प्लेट है जिसका प्रतिपादन किया जाएगा और दूसरा एक मूल तत्व है जिसका हमने ऊपर उल्लेख किया है।
meteorApp.js
Meteor.startup(function () {
if(Meteor.isClient) {
var myNewTemplate = Template.myNewTemplate;
var myContainer = document.getElementById('myContainer');
Blaze.render(myNewTemplate, myContainer);
}
});
डेटा के साथ रेंडर
यदि आपको प्रतिक्रियात्मक रूप से कुछ डेटा पास करने की आवश्यकता है, तो आप उपयोग कर सकते हैं renderWithDataतरीका। HTML पिछले उदाहरण की तरह ही होगा।
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div id = "myContainer">
</div>
</body>
<template name = "myNewTemplate">
<p>Text from my new template...</p>
</template>
हम दूसरे तर्क के रूप में अपना डेटा जोड़ सकते हैं Meteor.renderWithDataतरीका। अन्य दो तर्क पिछले उदाहरण के समान हैं। इस उदाहरण में, हमारा डेटा एक फ़ंक्शन है जो कुछ पाठ लॉग करेगा।
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);
}
});
विधि निकालें
हम जोड़ सकते हैं remove तरीका।
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div id = "myContainer">
</div>
</body>
<template name = "myNewTemplate">
<p>Text from my new template...</p>
</template>
इस उदाहरण में, हम तीन सेकंड के बाद हटाए जाने वाले टेम्पलेट को प्रस्तुत कर रहे हैं। ध्यान देंBlaze.Remove वह तरीका जिसे हम टेम्पलेट निकालने के लिए उपयोग कर रहे हैं।
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);
}
});
निम्न तालिका अन्य विधियों को दिखाती है जिनका उपयोग किया जा सकता है।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | Blaze.getData([elementOrView]) रेंडरिंग तत्व से डेटा प्राप्त करने के लिए उपयोग किया जाता है। |
2 | Blaze.toHTML(templateOrView) स्ट्रिंग के लिए टेम्प्लेट या दृश्य प्रदान करने के लिए उपयोग किया जाता है। |
3 | Blaze.toHTMLWithData(templateOrView, data) अतिरिक्त डेटा के साथ स्ट्रिंग के लिए टेम्पलेट या दृश्य प्रदान करने के लिए उपयोग किया जाता है। |
4 | new Blaze.View([name], renderFunction) DOM का नया ब्लेज़ रिएक्टिव हिस्सा बनाने के लिए उपयोग किया जाता है। |
5 | Blaze.currentView वर्तमान दृश्य प्राप्त करने के लिए उपयोग किया जाता है। |
6 | Blaze.getView([element]) वर्तमान दृश्य प्राप्त करने के लिए उपयोग किया जाता है। |
7 | Blaze.With(data, contentFunc) एक ऐसी सामग्री के निर्माण के लिए उपयोग किया जाता है जो संदर्भ के साथ कुछ सामग्री प्रदान करती है। |
8 | Blaze.If(conditionFunc, contentFunc, [elseFunc]) कुछ सशर्त सामग्री प्रदान करने वाले दृश्य के निर्माण के लिए उपयोग किया जाता है। |
9 | Blaze.Unless(conditionFunc, contentFunc, [elseFunc]) एक दृश्य के निर्माण के लिए उपयोग किया जाता है जो कुछ सशर्त सामग्री (उलटा) प्रदान करता है Blaze.if)। |
10 | Blaze.Each(argFunc, contentFunc, [elseFunc]) प्रस्तुत करने वाले दृश्य के निर्माण के लिए उपयोग किया जाता है contentFunct हर सामान के लिए। |
1 1 | new Blaze.Template([viewName], renderFunction) नाम और सामग्री के साथ एक नया ब्लेज़ दृश्य बनाने के लिए उपयोग किया जाता है। |
12 | Blaze.isTemplate(value) सही रिटर्न के लिए उपयोग किया जाता है, यदि मूल्य एक टेम्पलेट ऑब्जेक्ट है। |
उल्का अपने स्वयं के प्रदान करता है setTimeout तथा setIntervalतरीकों। इन विधियों का उपयोग यह सुनिश्चित करने के लिए किया जाता है कि सभी वैश्विक चर में सही मान हैं। वे नियमित जावास्क्रिप्ट की तरह काम करते हैंsetTimout तथा setInterval।
समय समाप्त
ये है Meteor.setTimeout उदाहरण।
Meteor.setTimeout(function() {
console.log("Timeout called after three seconds...");
}, 3000);
हम कंसोल में देख सकते हैं कि ऐप शुरू होने के बाद टाइमआउट फ़ंक्शन कहा जाता है।
मध्यान्तर
निम्नलिखित उदाहरण दिखाता है कि अंतराल कैसे सेट और साफ़ करना है।
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div>
{{> myTemplate}}
</div>
</body>
<template name = "myTemplate">
<button>CLEAR</button>
</template>
हम प्रारंभिक सेट करेंगे counter वैरिएबल जिसे हर इंटरवल कॉल के बाद अपडेट किया जाएगा।
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...')
}
});
}
कंसोल अपडेटेड लॉग करेगा counterचर हर तीन सेकंड। हम इसे क्लिक करके रोक सकते हैंCLEARबटन। यह कॉल करेगाclearInterval तरीका।
EJSON JSON सिंटैक्स का एक विस्तार है जो समर्थन करता है Date तथा Binary प्रकार के।
EJSON स्थापित करें
EJSON पैकेज स्थापित करने के लिए, हमें इसे कमांड प्रॉम्प्ट विंडो से जोड़ना होगा।
C:\Users\username\Desktop\meteorApp>meteor add ejson
तिथि उदाहरण
हम इसके बारे में दावा कर सकते हैं date का उपयोग करते हुए parse तरीका।
if (Meteor.isClient) {
var myEjsonDate = '{"$date": 1455029631493}';
var myDate = EJSON.parse(myEjsonDate);
console.log(myDate);
}
कंसोल सही दिनांक मान लॉग करेगा।
बाइनरी उदाहरण
उसी को बाइनरी प्रकारों पर लागू किया जा सकता है।
if (Meteor.isClient) {
var myEjsonBinary = '{"$binary": "c3VyZS4="}';
var myBinary = EJSON.parse(myEjsonBinary);
console.log(myBinary);
}
आप देख सकते हैं कि कंसोल नए deserialized मान लॉग कर रहा है।
Stringify
हम किसी वस्तु का उपयोग करके अनुक्रमित कर सकते हैं stringifyतरीका। यह ऊपर दिए गए उदाहरण से उलट प्रक्रिया है।
if (Meteor.isClient) {
var myObject = {
myDate : new Date(),
myBinary : new Uint8Array([115, 117, 114, 101, 46])
}
var myEjosnData = EJSON.stringify(myObject);
console.log(myEjosnData);
}
हम अपने नए मूल्यों को कंसोल में देख सकते हैं।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | EJSON.parse(string) EJSON मान में एक स्ट्रिंग पार्स करने के लिए उपयोग किया जाता है। |
2 | EJSON.stringify(value) स्ट्रिंग के लिए मान को क्रमांकित करने के लिए उपयोग किया जाता है। |
3 | EJSON.fromJSONValue(value) JSON से EJSON मान को डिसेर्लाइज़ करने के लिए उपयोग किया जाता है। |
4 | EJSON.toJSONValue(value) JSON में एक EJSON मान को क्रमांकित करने के लिए उपयोग किया जाता है। |
5 | EJSON.equals(value1, value2) तुलना करने के लिए उपयोग किया जाता है यदि दो मान समान हैं। |
6 | EJSON.clone(value) मूल्य की एक गहरी प्रति लौटाने के लिए उपयोग किया जाता है। |
7 | EJSON.newBinary बाइनरी डेटा असाइन करने के लिए उपयोग किया जाता है जिसे EJSON सीरियल कर सकता है। |
8 | EJSON.isBinary(x) यह जांचने के लिए उपयोग किया जाता है कि मान एक बाइनरी डेटा है या नहीं। |
9 | EJSON.addType(name, factory) कस्टम EJSON प्रकार बनाने के लिए उपयोग किया जाता है। |
10 | customType.typeName() कस्टम प्रकार का नाम वापस करने के लिए उपयोग किया जाता है। |
1 1 | customType.toJSONValue() कस्टम प्रकार को क्रमबद्ध करने के लिए उपयोग किया जाता है। |
12 | customType.clone() कस्टम प्रकार की गहरी प्रति लौटाने के लिए उपयोग किया जाता है। |
13 | customType.equals(otherValue) कस्टम प्रकार के मूल्य और अन्य मूल्य के बीच तुलना के लिए उपयोग किया जाता है। |
यह पैकेज HTTP अनुरोध एपीआई के साथ प्रदान करता है get, post, put तथा delete तरीकों।
पैकेज स्थापित करे
हम कमांड प्रॉम्प्ट विंडो में निम्न कोड चलाकर इस पैकेज को स्थापित करेंगे।
C:\Users\username\Desktop\meteorApp>meteor add http
कॉल विधि
यह सार्वभौमिक विधि है जिसका उपयोग कर सकते हैं GET, POST, PUT तथा DELETEतर्क। निम्न उदाहरण दर्शाता है कि कैसे उपयोग किया जाएGETबहस। इस अध्याय के उदाहरण इस वेबसाइट से नकली REST API का उपयोग करेंगे ।
आप देख सकते हैं कि यह विधि चार तर्कों का उपयोग कर रही है। हमने पहले तर्क का उल्लेख किया हैGET। दूसरा URL API URL है। तीसरा तर्क एक खाली वस्तु है, जहां हम कुछ वैकल्पिक पैरामीटर सेट कर सकते हैं। अंतिम विधि एक अतुल्यकालिक कॉलबैक है, जहां हम त्रुटियों को संभाल सकते हैं और प्रतिक्रिया के साथ काम कर सकते हैं।
HTTP.call( 'GET', 'http://jsonplaceholder.typicode.com/posts/1', {},
function( error, response ) {
if (error) {
console.log(error);
} else {
console.log(response);
}
});
विधि प्राप्त करें
उसी अनुरोध का उपयोग करके भेजा जा सकता है GET के बजाय CALLतरीका। आप देख सकते हैं कि अब पहला तर्क API URL है।
HTTP.get('http://jsonplaceholder.typicode.com/posts/1', {}, function( error, response ) {
if ( error ) {
console.log( error );
} else {
console.log( response );
}
});
पिछले दोनों उदाहरण समान आउटपुट को लॉग करेंगे।
पोस्ट विधि
इस विधि में, हम सर्वर पर भेजे जाने वाले डेटा को सेट कर रहे हैं (postData) दूसरे तर्क के रूप में। बाकी सब कुछ हमारे जैसा ही हैGET निवेदन।
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);
}
});
कंसोल हमारे लॉग करेगा postData वस्तु।
PUT विधि
हम अपने डेटा का उपयोग करके अपडेट कर सकते हैं PUTतरीका। अवधारणा हमारे पिछले उदाहरण के समान है।
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 );
}
});
अब, हम अपनी अपडेट की गई वस्तु को कंसोल में देख सकते हैं।
DEL विधि
हम सर्वर का उपयोग करके एक डिलीट अनुरोध भेज सकते हैं DELतरीका। हम अंदर सब कुछ हटा देंगेdata वस्तु।
var deleteData = {
data: {}
}
HTTP.del( 'http://jsonplaceholder.typicode.com/posts/1', deleteData,
function( error, response ) {
if ( error ) {
console.log( error );
} else {
console.log( response );
}
});
कंसोल दिखाएगा कि हटाने की प्रक्रिया सफल है।
इस पैकेज का उपयोग तब किया जाता है जब आपको Meteor App से एक ईमेल भेजने की आवश्यकता होती है।
चरण 1 - पैकेज जोड़ें
कमांड प्रॉम्प्ट विंडो खोलें और निम्न कमांड चलाएँ -
C:\Users\username\Desktop\meteorApp>meteor add email
चरण 2 - मेलबॉक्स खाता
हमें यहां एक खाता बनाने की आवश्यकता है । यह Meteor ऐप्स के लिए डिफ़ॉल्ट ईमेल प्रदाता है।
लॉग इन करने के बाद, खोलें Domains टैब और क्लिक करें sandbox URL नीचे Domain Name। यह एक नया पेज खोलेगा जहाँ हम पा सकते हैंDefault SMTP Login तथा Default Password। बनाने के लिए हमें इन दोनों की आवश्यकता होगीMAIL_URL वातावरण विविधता।
ईमेल भेजें
वैध बनाने के लिए MAIL_URL बस के स्थान पर अपने Mailgun क्रेडेंशियल्स डालें YOUR_DEFAULT_SMTP_LOGIN तथा 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..."
});
});
}
जब आप ऐप चलाते हैं, तो ईमेल आपके पते पर भेजा जाएगा।
स्थैतिक सर्वर संपत्ति में स्थित हैं privateऐप के अंदर सबफ़ोल्डर। निम्नलिखित उदाहरण में, हम सीखेंगे कि एक साधारण JSON फ़ाइल से डेटा का उपयोग कैसे करें।
चरण 1 - फ़ाइलें और फ़ोल्डर बनाएँ
आइए बनाते हैं a private फ़ोल्डर और my-json.jsonउस फोल्डर के अंदर फाइल करें। हम निम्नलिखित कमांड का उपयोग करते हुए करेंगेcommand prompt हालाँकि, आप इसे मैन्युअल रूप से भी बना सकते हैं।
C:\Users\username\Desktop\meteorApp>mkdir private
C:\Users\username\Desktop\meteorApp\private>touch my-json.json
चरण 2 - पाठ प्राप्त करें
हमारी फ़ाइल से डेटा पढ़ने में सक्षम होने के लिए, हम उपयोग करेंगे Asssets.getTextतरीका। ध्यान दें, यह केवल सर्वर की ओर से किया जा सकता है। चूँकि हम JSON का उपयोग कर रहे हैं, हमें इसे पार्स करने की आवश्यकता है।
if (Meteor.isServer) {
var myFile = JSON.parse(Assets.getText('my-json.json'));
console.log(myFile.data.text)
}
निम्नलिखित कमांड प्रॉम्प्ट विंडो में आउटपुट होगा।
चरण 3 - EJSON फ़ाइल बनाएँ
हम इस फ़ाइल को अंदर बनाएंगे privateफ़ोल्डर। इस फ़ाइल में बाइनरी डेटा होगा"myBinary": {"$binary": "c3VyZS4="}
C:\Users\username\Desktop\meteorApp\private>touch my-ejson.ejson
चरण 4 - बाइनरी प्राप्त करें
EJSON फ़ाइलों को पढ़ने के लिए, हम इसका उपयोग कर सकते हैं Assets.getBinary तरीका।
if (Meteor.isServer) {
var myFile = Assets.getBinary('my-ejson.ejson');
console.log(EJSON.stringify(myFile));
}
कमांड प्रॉम्प्ट EJSON मान लॉग करेगा।
इस अध्याय में, हम सीखेंगे कि कैसे अपने ऐप को सुरक्षित किया जाए और ऐप को विकसित करते समय किन बातों का ध्यान रखा जाए।
ऑटोप्रिज़म और ऑटोसेक्योर
Autopublishएक पैकेज है जो डेटाबेस से क्लाइंट तक सभी डेटा को स्वचालित रूप से प्रकाशित करता है। यह एक सुविधा है जिसे उत्पादन में अक्षम किया जाना चाहिए। इसे कमांड प्रॉम्प्ट से अक्षम किया जा सकता है।
C:\Users\username\Desktop\meteorApp>meteor remove autopublish
आप उपयोग करके क्लाइंट को कुछ डेटा प्रकाशित कर सकते हैं Meteor.publish() तथा Meteor.subscribe() तरीके जो हम पब्लिश और सब्सक्राइब चैप्टर में कवर करेंगे।
Insecureएक पैकेज है जो MongoDB कमांड्स को डेवलपर के कंसोल में लिखने की अनुमति देता है, ताकि ऐप का प्रत्येक उपयोगकर्ता डेटाबेस तक पहुंचने में सक्षम हो। कमांड प्रॉम्प्ट में निम्नलिखित कमांड को चलाकर पैकेज को हटाया जा सकता है।
C:\Users\username\Desktop\meteorApp>meteor remove insecure
अच्छा अभ्यास यह है कि जैसे ही आप अपने ऐप को विकसित करना शुरू करते हैं, दोनों ही पैकेजों को हटा दिया जाता है, इसलिए आपको बाद में अपना कोड बदलना और अपडेट नहीं करना है।
सर्वर साइड तरीकों का उपयोग करें
आपको हमेशा सर्वर पर अपने तरीके बनाने चाहिए। आप इसका उपयोग करके कर सकते हैंMeteor.methods() सर्वर पर और Meteor.call()ग्राहक पर। हम इसके बारे में मेथड्स चैप्टर में अधिक जानेंगे।
अतिरिक्त सुरक्षा
यदि आप अपने ऐप में सुरक्षा की अतिरिक्त परतें जोड़ना चाहते हैं, तो आपको कुछ अन्य उल्का पैकेजों का उपयोग करने पर विचार करना चाहिए जैसे -
ब्राउज़र नीति का उपयोग उन बाहरी संसाधनों को नियंत्रित करने के लिए किया जा सकता है जिन्हें आपके ऐप पर लोड किया जाना चाहिए।
चेक पैकेज का उपयोग उपयोगकर्ता इनपुट प्रकारों को संसाधित करने से पहले जांचने के लिए किया जा सकता है।
ऑडिट तर्क जांच एक ऐसा पैकेज है जो सुनिश्चित करने से पहले सभी मापदंडों को संसाधित करने से पहले सही तरीके से जांच करेगा। यदि आप कुछ मापदंडों से चूक गए हैं, तो यह पैकेज आपको सूचित करेगा।
Mylar संकुल सुरक्षा की कुछ अतिरिक्त परतों को जोड़ सकता है। आप उन्हें बाहर की जाँच कर सकते हैं यदि आपको उस तरह की सुरक्षा की आवश्यकता है।
डेटाबेस से प्राप्त करने के बाद हम डेटा को सॉर्ट कर सकते हैं। निम्नलिखित उदाहरण में, हम बनाएंगेUsersसंग्रह। हम एक का उपयोग करेंगेsort बहस ({sort: {name: 1}}) संग्रह डेटा को नाम से सॉर्ट करने के लिए। जो नंबर1आरोही क्रम को सेट करने के लिए उपयोग किया जाता है। यदि हम अवरोही क्रम का उपयोग करना चाहते हैं, तो हम उपयोग करेंगे-1 बजाय।
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);
हम उसी तरह से ईमेल द्वारा डेटा को सॉर्ट कर सकते हैं।
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);
अंत में, हम इसे जुड़ने की तारीख से सॉर्ट कर सकते हैं।
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);
यह पैकेज पूर्ण उपयोगकर्ता प्रमाणीकरण कार्यक्षमता की अनुमति देता है। आप कमांड प्रॉम्प्ट विंडो में निम्न कोड चलाकर इसे जोड़ सकते हैं।
C:\Users\username\Desktop\meteorApp>meteor add accounts-password
प्रमाणीकरण उदाहरण
यह उदाहरण मूल प्रमाणीकरण दिखाएगा। हम बनाएंगेregister, login, तथा homeटेम्पलेट्स। अगर वहां एक हैcurrentUser (यदि उपयोगकर्ता सफलतापूर्वक पंजीकृत है या लॉग इन है), homeटेम्प्लेट दिखाया जाएगा। अगर वहाँ कोई नहीं हैcurrentUser, को register तथा login टेम्प्लेट दिखाई देंगे।
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>
सबसे पहले, हमें एक बनाने की जरूरत है registerप्रतिस्पर्धा। यह फ़ंक्शन रजिस्टर इनपुट्स को पढ़ेगा, एक नया उपयोगकर्ता बनाएगा, और इसे डेटाबेस में संग्रहीत करेगा।
दूसरी घटना है login। इस बार यह फंक्शन इनपुट पढ़ेगाlogin टेम्पलेट, उपयोगकर्ता में लॉग इन करें यदि ईमेल और पासवर्ड मान्य हैं या यदि वे नहीं हैं तो एक त्रुटि वापस करें।
और अंत में द logout बटन क्लिक करने के बाद ईवेंट का उपयोग उपयोगकर्ता को लॉग आउट करने के लिए किया जाएगा।
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);
}
});
}
});
}
एक बार ऐप शुरू होने के बाद, हमें निम्न पेज मिलेगा।
ईमेल और पासवर्ड दर्ज करने पर registerफ़ॉर्म, हम नए उपयोगकर्ता को पंजीकृत और लॉगिन कर सकते हैं। हम देखेंगे कि कंसोल उपयोगकर्ताओं को लॉग करता हैid और यह home टेम्पलेट प्रदान किया गया है।
loginईवेंट डेटाबेस और उपयोगकर्ता में लॉग इन करेगा, अगर ईमेल और पासवर्ड सही हैं। यदि नहीं, तो कंसोल एक त्रुटि लॉग करेगा।
यदि उपयोगकर्ता क्लिक करता है LOGOUT बटन, ऐप उपयोगकर्ता को लॉग आउट करेगा और दिखाएगा register तथा login टेम्पलेट्स।
उल्का विधियां फ़ंक्शन हैं जो सर्वर साइड पर लिखे गए हैं, लेकिन क्लाइंट की तरफ से कॉल किए जा सकते हैं।
सर्वर की ओर, हम दो सरल तरीके बनाएंगे। पहला हमारे तर्क में 5 जोड़ देगा, जबकि दूसरा जोड़ देगा10।
विधियों का उपयोग करना
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);
}
});
}
एक बार जब हम ऐप शुरू करते हैं, तो हम कंसोल में परिकलित मान देखेंगे।
त्रुटियों को संभालना
त्रुटियों से निपटने के लिए, आप इसका उपयोग कर सकते हैं Meteor.Errorतरीका। निम्न उदाहरण दिखाता है कि लॉग इन नहीं करने वाले उपयोगकर्ताओं के लिए त्रुटि को कैसे संभालना है।
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);
}});
}
कंसोल हमारे अनुकूलित त्रुटि संदेश को दिखाएगा।
इस अध्याय में, हम सीखेंगे कि अपना उल्का पैकेज कैसे बनाया जाए।
पैकेज बनाना
आइए डेस्कटॉप पर एक नया फ़ोल्डर जोड़ें, जहां पैकेज बनाया जाएगा। हम कमांड प्रॉम्प्ट विंडो का उपयोग करेंगे।
C:\Users\username\Desktop\meteorApp> mkdir packages
अब, हम उस फ़ोल्डर में पैकेज बना सकते हैं जिसे हमने ऊपर बनाया है। कमांड प्रॉम्प्ट से निम्न कमांड चलाएँ।Username उल्का डेवलपर उपयोगकर्ता नाम है और package-name पैकेज का नाम है।
C:\Users\username\Desktop\meteorApp\packages>meteor create --package username:package-name
एक पैकेज जोड़ना
हमारे ऐप में एक स्थानीय पैकेज जोड़ने में सक्षम होने के लिए, हमें सेट करने की आवश्यकता है ENVIRONMENT VARIABLEजो उल्कापिंड को स्थानीय फ़ोल्डर से पैकेज लोड करने के लिए कहेगा। कंप्यूटर आइकन पर राइट-क्लिक करें और चुनेंproperties/Advanced system settings/Environment Variables/NEW।
Variable Name होना चाहिए PACKAGE_DIRS. Variable Valueहमारे द्वारा बनाए गए फ़ोल्डर का पथ होना चाहिए। हमारे मामले में,C:\Users\username\Desktop\meteorApp\packages।
पुनः आरंभ करने के लिए मत भूलना command prompt एक नया पर्यावरण चर जोड़ने के बाद।
अब हम निम्नलिखित कोड को चलाकर पैकेज को अपने ऐप में जोड़ सकते हैं -
C:\Users\username\Desktop\meteorApp>meteor add username:package-name
पैकेज फ़ाइलें
हमारे द्वारा बनाए गए पैकेज में निम्नलिखित चार फाइलें मिलेंगी।
- package-name-test.js
- package-name.js
- package.js
- README.md
परीक्षण पैकेज (पैकेज-नाम-test.js)
उल्का प्रदान करता है tinytestपरीक्षण के लिए पैकेज। कमांड प्रॉम्प्ट विंडो में निम्नलिखित कमांड का उपयोग करके इसे पहले स्थापित करें।
C:\Users\username\Desktop\meteorApp>meteor add tinytest
अगर हम खोलते हैं package-name-test.js, हम डिफ़ॉल्ट परीक्षा उदाहरण देखेंगे। हम इस उदाहरण का उपयोग ऐप का परीक्षण करने के लिए करेंगे। नोट: उल्का पैकेज विकसित करते समय हमारे अपने परीक्षण लिखना हमेशा बेहतर होता है।
पैकेज का परीक्षण करने के लिए, कमांड प्रॉम्प्ट में इस कोड को चलाते हैं।
C:\Users\username\Desktop>meteor test-packages packages/package-name
हम निम्नलिखित परिणाम प्राप्त करेंगे।
package.js फ़ाइल
यह वह फाइल है जहां हम कोड लिख सकते हैं। आइए हमारे पैकेज के लिए कुछ सरल कार्यक्षमता बनाएं। हमारा पैकेज कंसोल में कुछ पाठ लॉग करेगा।
संकुल / package.js
myPackageFunction = function() {
console.log('This is simple package...');
}
पैकेज- name.js फ़ाइल
यह वह फाइल है जहां हम कुछ पैकेज कॉन्फ़िगरेशन सेट कर सकते हैं। हम इसे बाद में वापस प्राप्त करेंगे, लेकिन अभी हमें निर्यात करने की आवश्यकता हैmyPackageFunctionइसलिए हम इसे अपने ऐप में उपयोग कर सकते हैं। हमें इसे अंदर जोड़ने की जरूरत हैPackage.onUseसमारोह। फ़ाइल कुछ इस तरह दिखाई देगी।
संकुल / पैकेज-name.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');
});
पैकेज का उपयोग करना
अब हम अंत में कॉल कर सकते हैं myPackageFunction() हमारे से meteorApp.js फ़ाइल।
संकुल / package.js
if(Meteor.isClient) {
myPackageFunction();
}
कंसोल हमारे पैकेज से टेक्स्ट को लॉग करेगा।
बेहतर समझने के लिए कैसे package.js फ़ाइल को कॉन्फ़िगर किया जा सकता है, हम उल्का के आधिकारिक प्रलेखन से उदाहरण का उपयोग करेंगे।
यह एक उदाहरण फ़ाइल है ...
/* 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"
});
जैसा कि पहले ही कलेक्शन चैप्टर में चर्चा की जा चुकी है, हमारा सारा डेटा क्लाइंट की तरफ उपलब्ध है। यह एक सुरक्षा मुद्दा है जिसे प्रकाशित और सदस्यता विधियों से संभाला जा सकता है।
स्वतःप्रकाश हटा रहा है
इस उदाहरण में, हम उपयोग करेंगे PlayersCollectionनिम्नलिखित डेटा के साथ संग्रह। हमने इस संग्रह को पहले अध्याय पर ध्यान केंद्रित करने में सक्षम होने के लिए तैयार किया। यदि आप अनिश्चित हैं कि उल्का ऐप में MongoDB संग्रह कैसे बनाया जाए, तो हमारे संग्रह अध्याय की जांच करें ।
हमारे डेटा को सुरक्षित करने के लिए, हमें निकालने की आवश्यकता है autopublish पैकेज जो हमें क्लाइंट की ओर से डेटा का उपयोग करने की अनुमति दे रहा था।
C:\Users\username\Desktop\meteorApp>meteor remove autopublish
इस चरण के बाद, हम क्लाइंट की ओर से डेटाबेस डेटा प्राप्त नहीं कर पाएंगे। हम केवल कमांड प्रॉम्प्ट विंडो में सर्वर की ओर से इसे देख पाएंगे। निम्नलिखित कोड चेकआउट करें -
meteorApp.js
var PlayersCollection = new Mongo.Collection('playersCollection');
var myLog = PlayersCollection.find().fetch();
console.log(myLog);
command prompt खिड़की चार वस्तुओं के साथ पूरे संग्रह को दिखाएगा, जबकि संग्रह developers consoleएक खाली सरणी दिखाएगा। अब हमारा ऐप अधिक सुरक्षित है।
प्रकाशन और सदस्यता का उपयोग करना
मान लीजिए कि हम ग्राहकों को हमारे डेटा का उपयोग करने की अनुमति देना चाहते हैं। इसके लिए हमें सृजन करना होगाMeteor.publish()सर्वर पर विधि। यह विधि क्लाइंट को डेटा भेज देगी।
क्लाइंट की ओर से उस डेटा को प्राप्त करने और उसका उपयोग करने में सक्षम होने के लिए, हम बनाएंगे Meteor.subscribe()तरीका। उदाहरण के अंत में, हम डेटाबेस खोज रहे हैं। यह कोड क्लाइंट और सर्वर दोनों तरफ से चल रहा है।
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);
हम देख सकते हैं कि हमारा डेटा दोनों में लॉग इन है developers console और यह command prompt खिड़की।
फ़िल्टरिंग क्लाइंट डेटा
हम डेटा का हिस्सा भी प्रकाशित कर सकते हैं। इस उदाहरण में, हम साथ डेटा प्रकाशित कर रहे हैं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);
एक बार जब हम इस कोड को चलाते हैं, command prompt ग्राहक की ओर से सभी डेटा लॉग करेगा console सिर्फ नाम के साथ दो वस्तुओं को लॉग करेगा John।
उल्का कुछ विशेष फ़ोल्डर्स प्रदान करता है जो डेवलपर्स को उनके ऐप को संरचित करने में मदद कर सकते हैं।
ग्राहक
अगर आप क्रिएट करते हैं clientफ़ोल्डर, इस फ़ोल्डर के अंदर सब कुछ क्लाइंट साइड पर चलाया जाएगा। यह वह फ़ोल्डर है जहाँ आप अपना स्थान रख सकते हैंHTML, CSS, और ग्राहक पक्ष JavaScript। आपको जगह चाहिएMeteor.subscribe काम करता है, templates, helpers, तथा eventsइस फ़ोल्डर के अंदर। ध्यान दें, आपको चलाने की आवश्यकता नहीं हैMeteor.isClient फ़ाइलों के अंदर कार्य किया जाता है client फ़ोल्डर।
सर्वर
इस फ़ोल्डर से फ़ाइलें केवल पर चलेंगी server side। यह वह जगह है जहाँmethods, Meteor.Publish()फ़ंक्शंस, और अन्य संवेदनशील डेटा को आयोजित किया जाना चाहिए। प्रमाणीकरण डेटा के सभी यहाँ आयोजित किया जाना चाहिए। आपको उपयोग करने की आवश्यकता नहीं हैMeteor.isServer() इस फ़ोल्डर के अंदर फ़ाइलों के लिए।
जनता
यह वह स्थान है जहां आपको अपनी छवियों, फेवीकोन्स, और अन्य सभी डेटा को क्लाइंट को परोसा जाना चाहिए।
निजी
इस फोल्डर की फाइलों को सर्वर से ही एक्सेस किया जा सकता है। इन्हें क्लाइंट से छिपाया जाएगा। आप रख सकते हैंJSON या EJSON फ़ाइलें जो केवल सर्वर इस फ़ोल्डर के अंदर उपयोग करेगी।
क्लाइंट / अनुकूलता
कुछ JavaScript लाइब्रेरी ग्लोबल्स के रूप में वेरिएबल एक्सपोर्ट करती हैं। फ़ाइलों के लिए इस फ़ोल्डर का उपयोग करें जिन्हें एक नए चर दायरे में लपेटे बिना निष्पादित करने की आवश्यकता है।
बाकी
बाकी फ़ोल्डरों को आपके इच्छित तरीके से संरचित किया जा सकता है। ऊपर वर्णित फ़ोल्डरों के बाहर रखा गया कोड निष्पादित किया जाएगाclient और यह serverपक्ष। यह एक अच्छी जगह है जहाँ आप अपने मॉडलों को परिभाषित कर सकते हैं।
लोड आदेश
फाइलों का लोड ऑर्डर जानना हमेशा अच्छा होता है। निम्नलिखित सूची उल्का आधिकारिक दस्तावेज से ली गई है।
HTML टेम्प्लेट फ़ाइलें हमेशा बाकी सब से पहले लोड की जाती हैं
से शुरू होने वाली फाइलें main. पिछले लोड किए गए हैं
किसी भी अंदर फ़ाइलें lib/ निर्देशिका को अगले लोड किया जाता है
गहरे रास्तों वाली फाइलें आगे लोड की जाती हैं
फ़ाइलों को पूरे पथ के एक वर्णमाला क्रम में लोड किया जाता है
उल्का के बारे में महान चीजों में से एक यह है कि ऐप को तैनात करना कितना आसान है। एक बार जब आपका ऐप पूरा हो जाता है, तो इसे दुनिया के साथ साझा करने का एक आसान तरीका है। आपको बस इतना करना है कि कमांड प्रॉम्प्ट विंडो में निम्न कोड चलाएं।
C:\Users\username\Desktop\meteorApp>meteor deploy my-first-app-ever.meteor.com
आपको उल्का डेवलपर्स खाते में प्रवेश करने के लिए कहा जाएगा username तथा password।
अब, आप अपने ऐप का नाम रखने वाले लिंक पर ब्राउज़र से ऐप को एक्सेस कर पाएंगे।
http://my-first-app-ever.meteor.com/
इस अध्याय में, हम सीखेंगे कि ऐप को एंड्रॉइड डिवाइस पर कैसे चलाना है। उल्का ने हाल ही में विंडोज़ ऑपरेटिंग सिस्टम के लिए इस कार्यक्षमता को जोड़ा है, इसलिए हमें अपने उल्का ऐप को 1.3 बीटा संस्करण में अपडेट करना होगा।
Note- इस ट्यूटोरियल को लिखने तक, Meteor का 1.3 संस्करण बीटा में है। उत्पादन संस्करण जारी होने के बाद हम इसे अपडेट करेंगे।
चूंकि हम नवीनतम उल्का संस्करण का उपयोग करना चाहते हैं, हम कमांड प्रॉम्प्ट विंडो में निम्न कोड चलाकर इसे अपडेट कर सकते हैं।
C:\Users\username\Desktop\meteorApp>meteor update --release 1.3-beta.11
चरण 1 - Android एसडीके स्थापित करें
एंड्रॉइड एसडीके को स्थापित करने के लिए निम्न तालिका में लिंक का उपयोग करें।
अनु क्रमांक। | सॉफ्टवेयर और विवरण |
---|---|
1 | Java Development Kit & Android SDK मोबाइल पर्यावरण पर उल्का ऐप चलाने में सक्षम होने के लिए आपको एंड्रॉइड एसडीके की आवश्यकता होगी। यदि आपके पास यह स्थापित नहीं है, तो आप हमारे Android पर्यावरण सेटअप ट्यूटोरियल की जांच कर सकते हैं । |
चरण 2 - एक Android प्लेटफ़ॉर्म जोड़ें
अब, हमें अपने प्रोजेक्ट में एक Android प्लेटफ़ॉर्म जोड़ना होगा।
C:\Users\username\Desktop\meteorApp>meteor add-platform android
चरण 3 - ऐप को एंड्रॉइड एमुलेटर पर चलाएं
एंड्रॉइड एमुलेटर पर ऐप को चलाने के लिए, हम उपयोग करेंगे –verbose स्टार्टअप प्रक्रिया के दौरान संभावित त्रुटियों की पहचान करने में सक्षम होने के लिए पंक्ति के अंत में कमांड।
C:\Users\username\Desktop\meteorApp>meteor run android --verbose
Android डिवाइस पर ऐप चलाएं
चूंकि एंड्रॉइड एमुलेटर धीमे हैं, इसलिए अपने ऐप को सीधे अपने डिवाइस पर चलाना बेहतर विकल्प है। आप डेवलपर्स के मोड और यूएसबी डिबगिंग को सक्षम करते हुए, डिवाइस को अपने कंप्यूटर से कनेक्ट करके कर सकते हैं।
विशिष्ट उपकरणों के लिए यह प्रक्रिया अलग है। आपको खोजने की जरूरत हैBuild Number में settings/Aboutऔर सात बार टैप करें। आपको एक सूचना मिलेगी कि आप डेवलपर हैं औरDeveloper Options अनलॉक किया जाएगा।
अपने माध्यम से खोजें settings फिर से और सक्षम करें USB debugging।
आप कमांड प्रॉम्प्ट में निम्नलिखित कमांड का उपयोग करके अपने मोबाइल डिवाइस पर उल्का ऐप चला सकते हैं।
C:\Users\username\Desktop\meteorApp>meteor run android-device
इस अध्याय में, हम सीखेंगे कि एक सरल टूडू ऐप कैसे बनाया जाए।
Step1 - एक ऐप बनाएं
कमांड प्रॉम्प्ट खोलें और निम्न कमांड चलाएँ -
C:\Users\username\Desktop>meteor create todo-app
ऐप को देखने के लिए, आपको ऐप को चलाने की आवश्यकता है meteor आज्ञा और जाओ http://localhost:3000
C:\Users\username\Desktop\todo-app>meteor
Step2 - फ़ोल्डर और फ़ाइलें बनाएँ
डिफ़ॉल्ट फ़ाइल संरचना के बजाय, हम इसे फिर से तैयार करेंगे। आइए बनाते हैं aclient फ़ोल्डर, जहाँ हम बनाएँगे todo-app.html, todo-app.css तथा 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
हम भी बनाएंगे server के साथ फ़ोल्डर server.js के भीतर।
C:\Users\username\Desktop\todo-app>mkdir server
C:\Users\username\Desktop\todo-app\server>touch server.js
अंत में, चलो बनाते हैं collections के साथ फ़ोल्डर task-collection.js अंदर फ़ाइल करें।
C:\Users\username\Desktop\todo-app>mkdir server
C:\Users\username\Desktop\todo-app\collections>touch task-collection.js
आप निम्न छवि पर एप्लिकेशन संरचना देख सकते हैं -
चरण 3 - ग्राहक / टूडू-ऐप। html
हमारा पहला विकास कदम ऐप के लिए HTML बनाना है। हमें एक इनपुट फ़ील्ड की आवश्यकता है जहाँ हम नए कार्य जोड़ सकते हैं। कार्य एक सूची के रूप में होंगेdelete तथा checkकार्यक्षमता। हमारे पास पूर्ण कार्यों को दिखाने या छिपाने के लिए कार्यशीलता भी होगी।
<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>
चरण 4 - संग्रह / कार्य-संग्रह.जेएस
यह वह जगह है जहां हम बस एक नया MongoDB संग्रह बनाएंगे, इसलिए हम इसे सर्वर और क्लाइंट दोनों तरफ से उपयोग कर सकते हैं।
Tasks = new Mongo.Collection("tasks");
चरण 5 - सर्वर / server.js
हम सर्वर साइड पर अपने ऐप के लिए तरीकों को परिभाषित करेंगे। इन तरीकों को क्लाइंट से बुलाया जाएगा। इस फ़ाइल में, हम डेटाबेस क्वेरी को भी प्रकाशित करेंगे।
// 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} });
}
});
चरण 6 - ग्राहक / टूडू-ऐप। जेएस
यह मुख्य क्लाइंट जावास्क्रिप्ट फ़ाइल है। इस फाइल को भी रिफलैक्ट किया जा सकता है लेकिन हम यहां सभी क्लाइंट साइड कोड लिखेंगे। सबसे पहले, हम सदस्यता लेते हैंtaskसंग्रह जो सर्वर पर प्रकाशित होता है। फिर, हम बनाते हैंhelpers एप्लिकेशन तर्क को संभालने में सक्षम होने के लिए, और अंत में, हम परिभाषित करते हैं events जो सर्वर से विधियों को कॉल करेगा।
// 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 - तैनात करें
हम विकास के साथ कर रहे हैं, हम कमांड प्रॉम्प्ट विंडो से एप्लिकेशन को तैनात कर सकते हैं। हमारे ऐप का परिनियोजन नाम होगाmy-first-todo-app।
C:\Users\username\Desktop\todo-app>meteor deploy my-first-todo-app
हम खोल सकते हैं http://my-first-todo-app.meteor.com/ हमारे app का उपयोग शुरू करने के लिए।
हमने पहले से ही पिछले अध्यायों में उल्का विकास की कुछ सर्वोत्तम प्रथाओं को कवर किया है। उल्कापिंड का उपयोग करते समय कुछ सर्वोत्तम प्रथाओं को ध्यान में रखा जाना चाहिए।
निर्देशिका संरचना
Meteor ऐप्स में डायरेक्टरी स्ट्रक्चर के बारे में कोई सख्त नियम नहीं हैं। दिशानिर्देशों के बारे में अधिक जानकारी के लिए, उल्का - संरचना अध्याय देखें।
विधियों का प्रयोग करें
कॉल करने के बजाय संवेदनशील डेटा के साथ काम करते समय आपको हमेशा उल्का - विधियों का उपयोग करना चाहिएinsert, update, तथा remove सीधे ग्राहक से।
डाटा प्रबंधन
प्रकाशन और सदस्यता विधियों का उपयोग करके अपने डेटा को सुरक्षित रखें । यदि आप चाहते हैं कि आपका डेटा सभी ग्राहकों के लिए उपलब्ध हो, तो आप उपयोग कर सकते हैंnullइसके बजाय प्रकाशन नाम के रूप में। डेटा का छोटा हिस्सा प्रकाशित करने से ऐप के प्रदर्शन में भी सुधार होगा।
डेटा मान्य करें
आपको उन सभी डेटा को मान्य करना चाहिए जो संग्रह के अंदर संग्रहीत किए जाएंगे। सबसे अच्छे विकल्पों में से एक संग्रह 2 पैकेज है। यह पैकेज सर्वर और क्लाइंट साइड सत्यापन को सेट करना आसान बनाता है।
सत्र को कम से कम करें
session चर वैश्विक चर हैं और ग्लोबल्स का उपयोग करना जावास्क्रिप्ट सर्वोत्तम प्रथाओं के खिलाफ है।
रूटर
Meteor रूटिंग के लिए दो सबसे लोकप्रिय विकल्प हैं। छोटे ऐप्स के लिए, आयरन राउटर है । डेटा में परिवर्तन होते ही यह स्वचालित रूप से फिर से चालू हो जाता है। बड़े ऐप्स के लिए, फ्लो राउटर है । यह राउटर आपको थोड़ी अधिक बॉयलरप्लेट कोड की कीमत पर टेम्प्लेट के पुन: प्रतिपादन को अनुकूलित करने की अधिक स्वतंत्रता देता है।
संकुल
हमेशा जांचें कि क्या पैकेज को नियमित रूप से अपडेट करने से पहले आप इसे अपने ऐप के अंदर उपयोग करना चाहते हैं।