Météore - Blaze
Blaze est un package Meteor pour créer des modèles réactifs en direct.
Méthode de rendu
Cette méthode est utilisée pour rendre les modèles dans le DOM. Tout d'abord, nous allons créermyNewTemplatequi sera rendu. Nous ajouterons égalementmyContainer, qui sera utilisé comme élément parent, donc le render La méthode sait où rendre notre modèle.
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div id = "myContainer">
</div>
</body>
<template name = "myNewTemplate">
<p>Text from my new template...</p>
</template>
Ensuite, nous allons créer une fonction de rendu qui prendra deux arguments. Le premier est un modèle qui sera rendu et le second est un élément parent que nous avons mentionné ci-dessus.
meteorApp.js
Meteor.startup(function () {
if(Meteor.isClient) {
var myNewTemplate = Template.myNewTemplate;
var myContainer = document.getElementById('myContainer');
Blaze.render(myNewTemplate, myContainer);
}
});
Rendu avec des données
Si vous avez besoin de transmettre certaines données de manière réactive, vous pouvez utiliser renderWithDataméthode. Le HTML sera exactement le même que dans l'exemple précédent.
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div id = "myContainer">
</div>
</body>
<template name = "myNewTemplate">
<p>Text from my new template...</p>
</template>
Nous pouvons ajouter nos données comme deuxième argument dans Meteor.renderWithDataméthode. Les deux autres arguments sont les mêmes que dans l'exemple précédent. Dans cet exemple, nos données sont une fonction qui enregistrera du texte.
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, méthode
Nous pouvons ajouter remove méthode.
meteorApp.html
<head>
<title>meteorApp</title>
</head>
<body>
<div id = "myContainer">
</div>
</body>
<template name = "myNewTemplate">
<p>Text from my new template...</p>
</template>
Dans cet exemple, nous rendons le modèle qui sera supprimé après trois secondes. Remarquez leBlaze.Remove méthode que nous utilisons pour supprimer le modèle.
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);
}
});
Le tableau suivant présente les autres méthodes qui peuvent être utilisées.
N ° Sr. | Méthode et détails |
---|---|
1 | Blaze.getData([elementOrView]) Utilisé pour récupérer les données de l'élément de rendu. |
2 | Blaze.toHTML(templateOrView) Utilisé pour rendre les modèles ou les vues à la chaîne. |
3 | Blaze.toHTMLWithData(templateOrView, data) Utilisé pour rendre des modèles ou des vues à la chaîne avec des données supplémentaires. |
4 | new Blaze.View([name], renderFunction) Utilisé pour créer une nouvelle partie réactive Blaze du DOM. |
5 | Blaze.currentView Utilisé pour obtenir la vue actuelle. |
6 | Blaze.getView([element]) Utilisé pour obtenir la vue actuelle. |
sept | Blaze.With(data, contentFunc) Utilisé pour construire une vue qui restitue du contenu avec un contexte. |
8 | Blaze.If(conditionFunc, contentFunc, [elseFunc]) Utilisé pour construire une vue qui restitue un contenu conditionnel. |
9 | Blaze.Unless(conditionFunc, contentFunc, [elseFunc]) Utilisé pour construire une vue qui restitue un contenu conditionnel (inversé Blaze.if). |
dix | Blaze.Each(argFunc, contentFunc, [elseFunc]) Utilisé pour construire une vue qui rend contentFunct pour chaque article. |
11 | new Blaze.Template([viewName], renderFunction) Utilisé pour créer une nouvelle vue Blaze avec le nom et le contenu. |
12 | Blaze.isTemplate(value) Utilisé pour renvoyer true, si la valeur est un objet modèle. |