Vue项目从搭建到部署

        

    2. 安装淘宝镜像CNPM

        使用npm下载依赖包是从国外服务器下载,可能会比较慢,可以安装淘宝的cnpm工具,它保持了与官方镜像包的同步,使用cnpm安装依赖包速度会快很多。

         npm install -g cnpm –registry=https://registry.npm.taobao.org

        

    3. 安装vue-cli

         vue-cli可以帮助我们快速生成页面开发脚手架。

         npm install -g vue-cli

         

         会在用户这个目录生成如下脚本工具:

         

    4. 生产webpack模板项目

         

         – Project name : 项目名称,注意名称不能存在大写字母!

         – Runtime …..   : 仅运行时,默认就行。

         下一步:

         

         – Install vue-router: 是否安装官方的vue-router,输入”y”

         下一步:

         

        – Use ESLint to lint your code ? 选择”Standard …..”,ESLint是代码风格管理工具,用来统一代码风格的,方便多人协作。

        下一步:

         

          单元测试,这里我选择”Karma and Mocha”

          下一步:

           

           下一步:

           

           下一步,完成配置,开始初始化项目目录:

            

            完成后,目录结构如下:

            

            //

           

           目录说明:

           – build : 使用npm run *** 执行的文件

           – config:  配置文件,build执行文件的配置信息

           – src: 资源文件,存放所有组件及所用到的图片, App.vue应用组件,我们编写的所有组件都在其上运行。

           – main.js : webpack的入口文件,如下可以看到:

              

                – package.json: npm管理的项目的文件,里面的内容不允许有注释。

    5. 运行、打包vue测试项目

        开发测试:npm run dev

        

        //

       

        打包:npm run build   

        

   

    打包后生成dist目录,最后的信息也说明了,生成的index.html文件如果在本地直接打开,是看不到页面的,需要把这个目录放到http服务器,如nginx等。

6. 部署

   这里部署使用pm2,没有直接放到nginx服务器,pm2是一个用来管理node进程的进程管理工具,支持查看node进程的状态、性能监控、负载均衡等。安装:npm install -g pm2 

    

    编写启动脚本:

    

    app.js:


 
 
  1. var port = 3298;
  2. var http = require( 'http');
  3. var url = require( 'url');
  4. var fs = require( 'fs');
  5. var path = require( 'path');
  6. var mine = require( './mine').types;
  7. var connect = require( 'connect');
  8. var history = require( 'connect-history-api-fallback');
  9. function access(request, response, next) {
  10. var pathname = url.parse(request.url).pathname;
  11. if (pathname.indexOf( "undefined")) {
  12. pathname = pathname.split( "undefined").join( "");
  13. }
  14. if (pathname== "/") {
  15. pathname = "/index.html";
  16. }
  17. var realPath = path.join( "./", pathname);
  18. var ext = path.extname(realPath);
  19. ext = ext ? ext.slice( 1) : 'unknown';
  20. fs.exists(realPath, function(exists) {
  21. if (!exists) {
  22. response.writeHead( 404, {
  23. 'Content-Type': 'text/plain'
  24. });
  25. response.write( "Request URL " + pathname + " not found on this server.");
  26. response.end();
  27. }
  28. else {
  29. fs.readFile(realPath, "binary", function(err, file){
  30. if (err) {
  31. response.writeHead( 500, {
  32. 'Content-Type': 'text/plain'
  33. });
  34. response.end(err);
  35. }
  36. else {
  37. var contentType = mine[ext] || "text/plain";
  38. response.writeHead( 200, {
  39. 'Content-Type': contentType
  40. })
  41. response.write(file, "binary");
  42. response.end();
  43. }
  44. });
  45. }
  46. });
  47. }
  48. var app = connect().use(history()).use(access);
  49. http.Server(app).listen(port);
  50. console.log( "vue-test serve at port :" + port + '......');

    mine.js:


 
 
  1. exports.types = {
  2. "css": "text/css",
  3. "gif": "image/gif",
  4. "html": "text/html",
  5. "ico": "image/x-icon",
  6. "jpeg": "image/jpeg",
  7. "jpg": "image/jpeg",
  8. "js": "text/javascript",
  9. "json": "application/json",
  10. "pdf": "application/pdf",
  11. "png": "image/png",
  12. "svg": "image/svg+xml",
  13. "swf": "application/x-shockwave-flash",
  14. "tiff": "image/tiff",
  15. "txt": "text/plain",
  16. "wav": "audio/x-wav",
  17. "wma": "audio/x-ms-wma",
  18. "wmv": "video/x-ms-wmv",
  19. "xml": "text/xml",
  20. "woff": "application/x-woff",
  21. "woff2": "application/x-woff2",
  22. "tff": "application/x-font-truetype",
  23. "otf": "application/x-font-opentype",
  24. "eot": "application/vnd.ms-fontobject"
  25. };

 

   启动: pm2 start app.js

   

    //

    

        停止: pm2 stop app 

        删除:    pm2 delete app



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值