Maison >interface Web >js tutoriel >Tutoriel nodejs pour créer un article simple publiant system_node.js

Tutoriel nodejs pour créer un article simple publiant system_node.js

WBOY
WBOYoriginal
2016-05-16 16:30:431786parcourir

Avant-propos

Nous allons créer un système de diffusion de nouvelles simple aujourd'hui. La première étape du système n'a pas besoin d'être trop difficile. Elle a principalement les fonctions suivantes

.

① Gestion des types d'actualités

② Gestion des actualités (avec fonction de téléchargement d'images)

③ Navigation dans les actualités

Bien qu'il n'y ait pas beaucoup de fonctions, il couvre également de nombreuses opérations de base. Le programme ajoute, supprime, vérifie et télécharge uniquement les pièces jointes, ce qui est suffisant. Alors commençons notre étude aujourd’hui

Préparation

Après les problèmes d'hier, nous disposons déjà des environnements nodeJS et mongoDB. Nous pouvons désormais créer directement de nouveaux fichiers de projet et fichiers de base de données

.

La première étape consiste à ouvrir l'invite de commande, à passer au lecteur D et à saisir

Copier le code Le code est le suivant :
D:>express -e news

Ensuite, le système construira automatiquement l'environnement de base avec bonheur

Évidemment, de nombreuses dépendances de modules ne sont pas là pour le moment, faites simplement le test du package.json d'hier :

Copier le code Le code est le suivant :

{
"name": "nom-application",
"version": "0.0.1",
"privé": vrai,
"scripts": {
"start": "node app.js"
},
"dépendances": {
"express": "3.4.8",
"ejs": "*",
"mongodb": "*"
>
>

Puis passez au répertoire du projet :

Copier le code Le code est le suivant :
nmp install

Une fois tous les fichiers dépendants téléchargés, nous entrons

Copier le code Le code est le suivant :

D:actualités>application de nœud
Serveur express en écoute sur le port 3000

Ainsi, notre programme s'est déroulé sans problème. Lorsque nous avons ouvert l'URL, nous avons constaté qu'il n'y avait effectivement aucun problème

PS : Il y a un problème qui mérite votre attention ici. Le fichier que nous avons téléchargé n'est pas encodé en UTF-8, donc le chinois peut être tronqué. L'encodage du fichier doit être unifié par vous-🎜>.

Lorsque le programme est en cours d'exécution, une configuration liée à la base de données est requise

① Créez d'abord un nouveau dossier d'actualités dans le répertoire mongoDB

② Ajouter le fichier de configuration settings.js au projet

Copier le code Le code est le suivant :
module.exports = {
cookieSecret : 'mesActualités',
db : 'nouvelles',
hôte : 'localhost'
};

③ Créez un nouveau répertoire models et créez un nouveau db.js

Copier le code Le code est le suivant :
var settings = require('../settings'),
Db = require('mongodb').Db,
Connexion = require('mongodb').Connexion,
Serveur = require('mongodb').Server;
module.exports = new Db(settings.db, new Server(settings.host, Connection.DEFAULT_PORT), { safe: true });

④ Créez un nouveau programme news.bat sur le bureau

Copier le code Le code est le suivant :
d:mongodbbinmongod.exe -dbpath d:mongodbnews
Pour démarrer la base de données à l'avenir, il nous suffit de l'exécuter. De cette façon, nos préparatifs préliminaires sont pratiquement terminés

.

Mais il y a deux choses ennuyeuses ici. L'une est qu'il est ennuyeux de démarrer le programme d'information à chaque fois, et l'autre est qu'il faut redémarrer pour modifier quoi que ce soit, nous allons donc d'abord résoudre ces deux problèmes ici

① Créez un nouveau news_app.bat sur le bureau et exécutez-le plus tard pour démarrer le programme

Copier le code Le code est le suivant :
noeud d:newsapp

② Supervisor est un programme de protection des processus. Nous pouvons l'utiliser pour nous aider à redémarrer le programme. Suivez d'abord, puis ajustez notre node_app.bat

.

Copier le code Le code est le suivant :
superviseur d:newsapp

Bien sûr, vous devez l'installer avant :

Copier le code Le code est le suivant :
npm install -g superviseur

Après cela, il n'est pas nécessaire de redémarrer manuellement après avoir modifié le fichier (news_app doit être placé dans le répertoire du projet), donc le travail de préparation se termine ici

Structure du projet

Après la première étape, il faut réfléchir à la structure du projet

① La page d'accueil est un index, où tous les types d'actualités et actualités seront répertoriés

② Chaque actualité comporte trois boutons : modifier/supprimer/afficher

③ La page d'accueil a un bouton pour ajouter des actualités (vous pouvez télécharger des photos lors de l'ajout)

Les fonctions de base sont comme ci-dessus

Nous avons donc supprimé la fonction de routage dans l'application et mis tous les itinéraires dans l'index

Copier le code Le code est le suivant :

//Mettez la fonction de routage dans index
//app.get('/', routes.index);
//app.get('/users', user.list);
itinéraires (application);

Copier le code Le code est le suivant :

module.exports = fonction (application) {
//Page d'accueil, maintenant aussi la page d'accueil
app.get('/', fonction (req, res) {
res.render('index', { title: 'Express' });
});
app.get('/add', fonction (req, res) {
res.send('Ajouter une demande de nouvelles');
});
app.get('/delete', fonction (req, res) {
res.send('Supprimer la demande d'actualité');
});
app.get('/view', fonction (req, res) {
res.send('Voir la demande d'actualité');
});
app.get('/update', fonction (req, res) {
res.send('Modifier la demande d'actualité');
});
};

La première étape est aussi simple que cela, car l'ajout de nouvelles doit avoir une page séparée, et cliquer sur le bouton ajouter aura un autre traitement, donc chaque demande doit être décomposée en interne. La réglementation actuelle est la suivante :

/ Page par défaut, qui affiche tous les genres et actualités, avec un bouton supprimer

/add Entrez dans la page d'ajout d'actualités

/addNews Ajouter une adresse de demande de publication spécifique à l'actualité (réponse en cliquant sur le bouton)

/delete Supprimer la demande d'actualité

/afficher une requête d'actualité spécifique

J'ai donc légèrement modifié l'itinéraire ci-dessus :

Copier le code Le code est le suivant :

module.exports = fonction (application) {
//Page d'accueil, maintenant aussi la page d'accueil
app.get('/', fonction (req, res) {
res.render('index', { title: 'Express' });
});
app.get('/add', fonction (req, res) {
res.send('Ajouter une page d'actualités');
});
app.post('/addNews', fonction (req, res) {
res.send('Traitement de la demande d'ajout de nouvelles');
});
app.get('/delete', fonction (req, res) {
res.send('Supprimer la demande d'actualité');
});
app.get('/view', fonction (req, res) {
res.send('Voir la demande d'actualité');
});
};

Nous devons donc créer plusieurs nouveaux modèles pour organiser nos pages Web. Ici, nous ne séparons pas la tête et la queue, juste la page la plus simple

.

Ajout de deux fichiers modèles, add et view, qui se comportent temporairement de la même manière que index.ejs, et modification de la navigation

Copier le code Le code est le suivant :

module.exports = fonction (application) {
//Page d'accueil, maintenant aussi la page d'accueil
app.get('/', fonction (req, res) {
res.render('index', { title: 'Express' });
});
app.get('/add', fonction (req, res) {
res.render('add', { title: 'Ajouter une page d'actualité' });
});
app.post('/addNews', fonction (req, res) {
res.send('Traitement de la demande d'ajout de nouvelles');
});
app.get('/delete', fonction (req, res) {
res.send('Supprimer la demande d'actualité');
});
app.get('/view', fonction (req, res) {
res.render('view', { title: 'View News Request' });
});
};

C'est la fin de la structure du projet

Opération de données

Une fois la structure globale terminée, nous devons effectuer des opérations sur les données :

① Ajouter des données (ajouter des actualités)

② Afficher les données (afficher les actualités)

③ Supprimer les données (supprimer les actualités)

À l'origine, cela impliquait également des opérations de type, mais je n'ai pas pu le comprendre en le faisant, je vais le laisser tranquille pour le moment, car il est facile de se perdre lorsqu'on le fait pour la première fois

Ajouter des actualités

Ici, nous n'utilisons pas la soumission de formulaire, nous utilisons ajax... Ici nous introduisons la bibliothèque zepto, donc notre page devient comme ça

Copier le code Le code est le suivant :





                                                                                                       




                                                                                   

Titre :


Contenu :


          






Bien qu'il n'y ait pas encore de programme de réponse aux requêtes, les données ne seront donc pas traitées, et nous n'avons pas de pièces jointes ici (une seule pièce jointe est autorisée maintenant), nous modifions donc le code et ajoutons des images :

PS : Le plus gênant c'est que le traitement ajax de l'image est un peu gênant, donc on revient juste à l'opération formulaire, sinon ça va prendre beaucoup de temps...

Copier le code Le code est le suivant :



   
        <%= titre %>

   


   


        <%= titre %>


   

   

        Remarque :
   

   

        Description :
   

   

        Nom :
   

   

       
   

   


这个样子就不需要过多的考虑附件问题,先暂时如此吧,现在先处理请求程序,这里先在public里面新建news文件夹用于存储其图片

modèle

在models文件夹新增news.js文件,为其构建实体,并赋予新增查询相关操作 :

复制代码 代码如下 :

var mongodb = require('./db');

fonction News(titre, contenu, photo) {
  this.title = titre;
  this.content = contenu;
  this.pic = pic;//保存存储路径
};
module.exports = Actualités;
//存储数据
Actualités.prototype = {
  save : fonction (rappel) {
    var date = nouvelle Date();
    var temps = {
      date : date,
      année : date.getFullYear(),
      mois : date.getFullYear() "-" (date.getMonth() 1),
      jour : date.getFullYear() "-" (date.getMonth() 1) "-" date.getDate(),
      minute : date.getFullYear() "-" (date.getMonth() 1) "-" date.getDate() " "
      date.getHours() ":" (date.getMinutes() < 10 ? '0' date.getMinutes() : date.getMinutes())
    >
    //数据存储对象
    var actualités = {
      titre : ce.titre,
      contenu : this.content,
      pic : this.pic, //图片处理最后来说,现在先乱存
      heure : heure
    };
    //打开数据连接,打开就是一个回调......
    mongodb.open (fonction (err, db) {
      //错误就退出
      si (erreur) {
        return callback(err);
      >
      //打开news集合
      db.collection('news', function (err, collection) {
        si (erreur) {
          mongodb.close();
          return callback(err);
        >
        //写入集合(写入数据库)
        collection.insert(news, {safe: true }, function (err) {
          return callback(err);
        });
        callback(null);//err为null
      });
    });
  >
};

Donc, le programme pour écrire dans la base de données est là. Ici, nous essayons de voir si nous pouvons l'insérer dans la base de données. Bien sûr, nous devons modifier le programme de routage

.

PS : Bien sûr, vous ne pouvez pas écrire trop de code logique dans le service de routage. Ce fichier devra être séparé à l'avenir

.

Pour le moment, la logique dans /addNews doit être modifiée

Copier le code Le code est le suivant :

app.post('/addNews', fonction (req, res) {
var titre = req.body.title;
var content = req.body.content;
var pic = req.body.pic;
var news = nouvelle News(titre, contenu, photo)
news.save (fonction (erreur, données) {
res.send(data);
})
});

Après vérification, le problème n'est pas grave. Ce qu'il faut maintenant résoudre, c'est le problème de l'attachement

Télécharger des photos

Express lui-même prend en charge la fonction de téléchargement d'images. Express analyse le corps de la requête via bodyParser, puis télécharge des fichiers via celui-ci. Il utilise formidable

en interne.

Ici, remplacez app.use(express.bodyParser()) dans app.js par :

Copier le code Le code est le suivant :
app.use(express.bodyParser({ keepExtensions: true , uploadDir : './public/news' }));

Ouvrez index.js et ajoutez une ligne de code devant :

Copier le code Le code est le suivant :
fs = require('fs'),

Modifier le fichier d'index :

Copier le code Le code est le suivant :

app.post('/addNews', fonction (req, res) {
pour (var i dans req.files) {
Si (req.files[i] == 0) {
//Supprimer un fichier de manière synchrone
         fs.unlinkSync(req.files[i].path);
console.log('succès supprimé un fichier vide');
} autre {
var path = './public/news/' req.files[i].name;
//Renommer un fichier en utilisant la méthode synchrone
          fs.renameSync(req.files[i].path, path);
console.log('suncess a renommé un fichier');
>
>
// var titre = req.body.title;
// var content = req.body.content;
// var pic = req.body.pic;
// var news = new News(titre, contenu, photo)
// news.save (fonction (erreur, données) {
// res.send(data);
// })
});

À ce moment, sélectionnez le fichier et cliquez sur Ajouter des actualités, et notre fichier sera téléchargé

Pour le moment, il me suffit d'enregistrer le nom du fichier dans la base de données, et il y aura des images dans le répertoire des fichiers

Copier le code Le code est le suivant :

app.post('/addNews', fonction (req, res) {
var pic = null;
pour (var i dans req.files) {
Si (req.files[i] == 0) {
//Supprimer un fichier de manière synchrone
         fs.unlinkSync(req.files[i].path);
console.log('succès supprimé un fichier vide');
} autre {
var path = './public/news/' req.files[i].name;
//Renommer un fichier en utilisant la méthode synchrone
          fs.renameSync(req.files[i].path, path);
console.log('suncess a renommé un fichier');
>
Pic = req.files[i].name;
>
var titre = req.body.title;
var content = req.body.content;
var news = nouvelle News(titre, contenu, photo)
news.save (fonction (erreur, données) {
res.send(data);
})
res.send('Demande réussie, retour à la page d'accueil');
});

Il y a des données dans la base de données et il y a des fichiers dans notre répertoire. Il ne nous reste plus qu'à lire les données

.

PS : Des frères m'incitent à sortir boire un verre pendant les vacances

Lire les données

La deuxième étape consiste bien sûr à lire les données. La première consiste à lire les données sur la page d'accueil :

Copier le code Le code est le suivant :

var mongodb = require('./db');
fonction Actualités (titre, contenu, photo) {
this.title = titre;
this.content = contenu;
this.pic = pic;//Enregistrer le chemin de stockage
};
module.exports = Actualités;
//Données de stockage
Actualités.prototype = {
save : fonction (rappel) {
var date = nouvelle Date();
//Objet de stockage de données
var actualités = {
titre : ce.titre,
Contenu : this.content,
Pic : this.pic, //Enfin, le traitement de l'image, maintenant enregistrez-la au hasard
date : date
};
//Ouvrez la connexion de données, l'ouverture est un rappel...
mongodb.open (fonction (err, db) {
//Quitter si une erreur se produit
Si (erreur) {
         return callback(err);
>
//Ouvrez la collection d'actualités
db.collection('news', function (err, collection) {
Si (erreur) {
             mongodb.close();
            return callback(err);
>
//Écrire la collection (écrire dans la base de données)
         collection.insert(news, {safe: true }, function (err) {
            return callback(err);
});
​​​​ callback(null); //l'erreur est nulle
});
});
>
};
//Lire l'article et ses informations associées
News.get = fonction (id, rappel) {
//Ouvrir la base de données
mongodb.open (fonction (err, db) {
Si (erreur) {
Rappel(err);
>
db.collection('news', function (err, collection) {
Si (erreur) {
          mongodb.close();
         return callback(err);
>
var requête = {};
Si (identifiant) {
​​​​ query.id = id;
>
//Requête d'articles basée sur un objet de requête
Collection.find(query).sort({
date : -1
}).toArray(function (erreur, données) {
          mongodb.close();
Si (erreur) {
             return callback(err); //Échec ! Erreur de retour
>
​​​​ callback(null, data); //Succès ! Renvoie les résultats de la requête sous forme de tableau
});
});
});
};
news.js

Copier le code Le code est le suivant :




   
        <%= titre %>

   


   


        <%= titre %>


   

            <%for(var k dans les données) { %>
           

  •            

                   Nom : <%=data[k].title %>

               

                  Nom :  <%=data[k].content%>

                 

                  Lire :

                 

             

              删除
             

             

       
        <%} %>
   


结语

好了,以后我们再慢慢增加功能,慢慢做美化。

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Article précédent:Notes d'étude Javascript : attribut de parcours de tableau et de longueur_Connaissances de baseArticle suivant:Notes d'étude Javascript : attribut de parcours de tableau et de longueur_Connaissances de base

Articles Liés

Voir plus