Utilisez vue2.0+element-ui+node.js+mongodb pour créer un système de blog spatial complet, imitant l'espace QQ, avec des modules tels que discussion, blog, album photo, message et amis.
Adresse en ligne : https://auven.github.io/pandazone/
Si vous ne connaissez pas node.js et mongoDB, vous pouvez lire les notes d'étude nodejs+express+mongodb pour commencer.
$ npm install# Si l'installation de la commande ci-dessus est lente, vous pouvez utiliser la commande suivante $ npm install --registry=https://registry.npm.taobao.org
Remarque : L'environnement de développement utilise des données réelles et MongoDB doit être installé.
Vous devez d'abord ouvrir la base de données MongoDB. Quant à la façon d'utiliser MongoDB, je n'expliquerai pas grand-chose ici, s'il vous plaît, Baidu vous-même.
# Installer les dépendances npm install # Initialiser la table des villes, utilisée pour enregistrer la source de données de ville de la page npm run initCitys # Démarrez le serveur et exécutez-le sur localhost:8080npm run dev
L'environnement de développement vue routage utilise le mode historique.
Dans un environnement de production, des données fictives sont utilisées. Si vous souhaitez remplacer des données réelles, veuillez modifier BASE_API
dans config/prod.env.js
.
# 打包压缩代码
npm run build
# 预览网页
node server/prod.server.js
L'environnement de production vue routage utilise le mode hachage.
Ce projet est mon projet de fin d'études. J'ai déjà implémenté ce site Web en utilisant PHP, mais comme j'apprends Vue récemment, j'ai utilisé Vue pour ce projet.
Technologies impliquées : vue2.0, express, node.js+mongodb, using element, PhotoSwipe, Baidu ueditor et autres plug-ins.
│ .babelrc │ .editorconfig │ .eslintignore │ .eslintrc.js │ .gitignore │ .postcssrc.js │ .travis.yml │ index.html │ package.json │ README.md │ ├─build // webpack配置文件 │ build.js │ check-versions.js │ dev-client.js │ dev-server.js │ initCitys.js │ utils.js │ vue-loader.conf.js │ webpack.base.conf.js │ webpack.dev.conf.js │ webpack.prod.conf.js │ webpack.test.conf.js │ ├─config // webpack配置文件 │ dev.env.js │ index.js │ prod.env.js │ test.env.js │ ├─dist // build之后的目录 │ ├─server // express服务器相关代码 │ │ prod.server.js │ │ settings.js │ │ │ ├─models // mongoose模块(与MongoDB进行数据交互) │ │ Album.js │ │ Blog.js │ │ BlogGroup.js │ │ db.js │ │ dbs.js │ │ Log.js │ │ md5.js │ │ Mood.js │ │ User.js │ │ │ ├─router // 服务器路由配置 │ │ router.js │ │ │ └─upload // 图片上传目录 │ ├─album // 相册 │ │ │ ├─avatar // 头像 │ │ │ ├─moodImg // 说说配图 │ │ │ └─temp // 临时上传文件 ├─src // vue项目源文件 │ │ App.vue │ │ main.js // 入口文件 │ │ │ ├─common // 公共 │ │ ├─fonts │ │ │ pandazone.eot │ │ │ pandazone.svg │ │ │ pandazone.ttf │ │ │ pandazone.woff │ │ │ │ │ └─stylus │ │ base.styl │ │ icon.styl │ │ index.styl │ │ mixin.styl │ │ │ ├─components // 组件 │ │ ├─404 │ │ │ 404.png │ │ │ 404.vue │ │ │ 404_msg.png │ │ │ 404_to_index.png │ │ │ error_bg.jpg │ │ │ error_cloud.png │ │ │ │ │ ├─album │ │ │ album.vue │ │ │ │ │ ├─albumDetail │ │ │ albumDetail.vue │ │ │ │ │ ├─blog │ │ │ blog.vue │ │ │ │ │ ├─blogDetail │ │ │ blogDetail.vue │ │ │ │ │ ├─blogModify │ │ │ blogModify.vue │ │ │ │ │ ├─footer │ │ │ footer.vue │ │ │ WechatIMG2.jpeg │ │ │ │ │ ├─friends │ │ │ friends.vue │ │ │ │ │ ├─header │ │ │ header.vue │ │ │ │ │ ├─home │ │ │ home.vue │ │ │ │ │ ├─index │ │ │ index.vue │ │ │ │ │ ├─login │ │ │ login.vue │ │ │ │ │ ├─message │ │ │ message.vue │ │ │ │ │ ├─mood │ │ │ mood.vue │ │ │ │ │ ├─newBlog │ │ │ newBlog.vue │ │ │ │ │ ├─newMood │ │ │ newMood.vue │ │ │ │ │ ├─profile │ │ │ profile.vue │ │ │ │ │ ├─register │ │ │ register.vue │ │ │ │ │ ├─status │ │ │ status.vue │ │ │ │ │ ├─uploadImg │ │ │ uploadImg.vue │ │ │ │ │ ├─userIndex │ │ │ userIndex.vue │ │ │ │ │ └─vueUeditor │ │ vueUeditor.vue │ │ │ └─router // vue-router │ index.js │ └─static // 静态资源文件 │ .gitkeep │ city.json │ ├─css │ normalize.css │ ├─images │ 72019_bg.jpg │ 72019_top.png │ moren.jpg │ ├─js │ └─PhotoSwipe │ └─ueditor1_4_3_3