pandazone
1.0
vue2.0+element-ui+node.js+mongodb を使用して、トーク、ブログ、フォト アルバム、メッセージ、友達などのモジュールを備えた、QQ スペースを模倣したフルスタック スペース ブログ システムを構築します。
オンラインアドレス: https://auven.github.io/pandazone/
node.js と mongoDB を知らない場合は、nodejs+express+mongodb の学習ノートを読んで始めることができます。
$ npm install# 上記のコマンドのインストールが遅い場合は、次のコマンドを使用できます $ npm install --registry=https://registry.npm.taabao.org
注:開発環境では実際のデータが使用されるため、MongoDB がインストールされている必要があります。
まず、MongoDB データベースを開く必要があります。MongoDB の使用方法については、ここでは詳しく説明しませんので、Baidu をご利用ください。
# 依存関係をインストールします npm install # ページの都市データ ソースの登録に使用される都市テーブルを初期化します npm run initCitys # サーバーを起動し、localhost:8080npm run dev で実行します
開発環境の vue ルーティングはヒストリー モードを使用します。
本番環境ではモックデータが使用されます。実際のデータを置き換える場合は、 config/prod.env.js
のBASE_API
変更してください。
# 打包压缩代码
npm run build
# 预览网页
node server/prod.server.js
本番環境の vue ルーティングはハッシュ モードを使用します。
このプロジェクトは私の卒業プロジェクトです。以前にこの Web サイトを PHP で実装しましたが、最近 Vue を学習しているので、このプロジェクトを実行するために Vue を使用しました。
関連するテクノロジー: vue2.0、express、node.js+mongodb、Element、PhotoSwipe、Baidu ueditor、その他のプラグインの使用。
│ .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