一,node版本

node: v14.18.0, npm: 6.14.15

二、下载项目和所需组件

  1. 直接下载zip包或通过git克隆到本地仓库,如下:

git clone https://github.com/daxiongYang/renren-fast-vue.git

  1. 下载所需的vue相关组件,逐个执行以下命令

    1. npm config set registry=http://registry.npm.taobao.org #配置淘宝的镜像
    2. npm config list #查看当前npm的配置信息

    下载必要的组件,执行以下命令

    1. npm install vue -g
    2. npm install vue-router -g
    3. npm install vue-cli -g
    4. #查看vue版本,V是大写
    5. vue -V

    更多的安装教程可以参考以下这篇博文,很详细,值得一看
    https://www.cnblogs.com/lgx5/p/10732016.html

    三、下载依赖

  2. 进入项目文件夹/renren_fast_vue ```css

    修改renren-fast-vue项目文件package.json,将npm版本由6.9改为6.14.15

    “npm”: “^6.14.15”,

npm install #下载依赖包,提前配置淘宝镜像,下载会快点

  1. 2. 下载依赖时可能会出现以下报错:
  2. - _**问题1:**_如下图,Downloading [https://chromedriver.storage.googleapis.com/2.27/chromedriver_win64.zip(明显是被墙了)](https://chromedriver.storage.googleapis.com/2.27/chromedriver_win64.zip%EF%BC%88%E6%98%8E%E6%98%BE%E6%98%AF%E8%A2%AB%E5%A2%99%E4%BA%86%EF%BC%89)![](https://cdn.nlark.com/yuque/0/2021/jpeg/10374550/1640324995235-8c7afe72-dbfd-40bb-b35f-a15b32e8f492.jpeg#clientId=u3df1cf8b-26b3-4&crop=0&crop=0&crop=1&crop=1&from=paste&id=u67963043&margin=%5Bobject%20Object%5D&originHeight=1031&originWidth=1920&originalType=url&ratio=1&rotation=0&showTitle=false&status=done&style=none&taskId=u9e6d5700-e50c-4c2e-8ebe-72eb04be4cb&title=)
  3. - _**解决办法:**_
  4. ```css
  5. #指定淘宝的镜像重新下载
  6. npm install chromedriver --chromedriver_cdnurl=http://cdn.npm.taobao.org/dist/chromedriver
  7. #下载后再次下载依赖
  8. npm install

四、启动项目

  1. 启动前端,在前端目录下执行命令
    1. npm run dev
  1. 启动时可能遇到的报错

问题2:启动前端时报错,如下图,node sass不支持当前环境,实质node-sass4.9.0安装失败
浏览器界面提示<% if (process.env.NODEENV === ‘production’) { %> <% }else { %> <% } %> 三,renren-fast-vue安装 - 图1
解决办法:_

  1. #清除当前的sass
  2. npm uninstall node-sass
  3. #重新安装sass,若没有报错,即可再次启动项目
  4. npm i node-sass --sass_binary_site=https://npm.taobao.org/mirrors/node-sass/
  5. #再次启动项目
  6. npm run dev
  1. 再次在浏览器打开http://localhost:8001,成功打开前端项目,提前启动后端即可正常登陆,用户admin/admin![](https://cdn.nlark.com/yuque/0/2021/png/10374550/1640324995073-cddafcb4-dc1c-40ab-ab75-0f8615473fd3.png#clientId=u3df1cf8b-26b3-4&crop=0&crop=0&crop=1&crop=1&from=paste&id=u3ed205d2&margin=%5Bobject%20Object%5D&originHeight=562&originWidth=1453&originalType=url&ratio=1&rotation=0&showTitle=false&status=done&style=none&taskId=u7c9e1e3e-4314-48d3-af42-eb84a65ab05&title=)

    五,编译打包

    问题描述
    1、下载了renren-fast-vue-master.zip以后,进行解压缩。
    2、打开cmd或者powershell窗口,切换到刚解压的目录下。 ```css

    执行npm install安装依赖的模块

    npm install

模块安装完毕后,执行npm run build —prod进行生产环境打包发布

npm run build —prod

  1. 这是就会报npm ERR! renren-fast-vue@1.2.2 build: gulp异常,详情如下:<br />![image.png](https://cdn.nlark.com/yuque/0/2021/png/10374550/1640326187017-4b248ef0-f39d-40b3-bb1f-99b5671afaf9.png#clientId=u1b77f341-da8a-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=431&id=u814be7fc&margin=%5Bobject%20Object%5D&name=image.png&originHeight=431&originWidth=705&originalType=binary&ratio=1&rotation=0&showTitle=false&size=177953&status=done&style=none&taskId=u6f5ba6e5-ed2b-49fa-a48c-6e6f95a1cab&title=&width=705)<br />**问题解决**<br />1、第一步是升级gulp到4.0
  2. ```css
  3. #配置淘宝的镜像
  4. npm config set registry=http://registry.npm.taobao.org
  5. ## 升级gulp到4.0
  6. npm install -g gulp-cli
  7. npm install --save-dev gulp@4
  8. ## 查看gulp版本
  9. gulp -v
  10. ## 我的版本输出如下
  11. ## CLI version: 2.3.0
  12. ## Local version: 4.0.2

2、第二步是修改gulpfile.js文件
gulpfile.js文件在renren-fast-vue项目的根目录下。
修改原因是:gulp4.0的语法跟以往版本不同。

  1. var gulp = require('gulp');
  2. var $ = require('gulp-load-plugins')();
  3. var path = require('path');
  4. var del = require('del');
  5. var distPath = path.resolve('./dist');
  6. var version = ''; // 版本号
  7. var versionPath = ''; // 版本号路径
  8. var env = process.env.npm_config_qa ? 'qa' : process.env.npm_config_uat ? 'uat' : 'prod'; // 运行环境
  9. // 创建版本号(年月日时分)
  10. (function () {
  11. var d = new Date();
  12. var yy = d.getFullYear();
  13. var MM = d.getMonth() + 1 >= 10 ? (d.getMonth() + 1) : '0' + (d.getMonth() + 1);
  14. var DD = d.getDate() >= 10 ? d.getDate() : '0' + d.getDate();
  15. var h = d.getHours() >= 10 ? d.getHours() : '0' + d.getHours();
  16. var mm = d.getMinutes() >= 10 ? d.getMinutes() : '0' + d.getMinutes();
  17. version = yy + MM + DD + h + mm;
  18. versionPath = distPath + '/' + version;
  19. })();
  20. // 编译
  21. gulp.task('build', $.shell.task([ 'node build/build.js' ]));
  22. // 创建版本号目录
  23. gulp.task('create:versionCatalog', function () {
  24. return gulp.src(`${distPath}/static/**/*`)
  25. .pipe(gulp.dest(`${versionPath}/static/`))
  26. });
  27. // 替换${versionPath}/static/js/manifest.js window.SITE_CONFIG.cdnUrl占位变量
  28. gulp.task('replace:cdnUrl', function () {
  29. return gulp.src(`${versionPath}/static/js/manifest.js`)
  30. .pipe($.replace(new RegExp(`"${require('./config').build.assetsPublicPath}"`, 'g'), 'window.SITE_CONFIG.cdnUrl + "/"'))
  31. .pipe(gulp.dest(`${versionPath}/static/js/`))
  32. });
  33. // 替换${versionPath}/static/config/index-${env}.js window.SITE_CONFIG['version']配置变量
  34. gulp.task('replace:version', function () {
  35. return gulp.src(`${versionPath}/static/config/index-${env}.js`)
  36. .pipe($.replace(/window.SITE_CONFIG\['version'\] = '.*'/g, `window.SITE_CONFIG['version'] = '${version}'`))
  37. .pipe(gulp.dest(`${versionPath}/static/config/`))
  38. });
  39. // 合并${versionPath}/static/config/[index-${env}, init].js 至 ${distPath}/config/index.js
  40. gulp.task('concat:config', function () {
  41. return gulp.src([`${versionPath}/static/config/index-${env}.js`, `${versionPath}/static/config/init.js`])
  42. .pipe($.concat('index.js'))
  43. .pipe(gulp.dest(`${distPath}/config/`))
  44. });
  45. //清除, 编译 / 处理项目中产生的文件
  46. gulp.task('cleanBuild', function () {
  47. return del([`${distPath}/static`, `${versionPath}/static/config`])
  48. });
  49. // 清空
  50. gulp.task('clean', function () {
  51. return del([versionPath])
  52. });
  53. //gulp.series|4.0 依赖
  54. //gulp.parallel|4.0 多个依赖嵌套
  55. gulp.task('default',gulp.series(gulp.series('build','create:versionCatalog','replace:cdnUrl','replace:version','concat:config','cleanBuild')));

3、第三步是重新执行生产环境打包命令

  1. npm run build --prod

image.png
这是已经在renren-fast-vue根目录下生成了dist目录。问题成功解决