Vue项目从搭建到部署

本文详细介绍了如何从安装Node.js和CNPM,到使用Vue CLI生成webpack模板项目,再到运行、打包Vue测试项目的过程。通过CLI2版本创建项目,并配置了ESLint、vue-router,还涉及了项目部署中使用pm2进行进程管理的步骤。

    1. 安装Node.js

        

    2. 安装淘宝镜像CNPM

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

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

        

    3. 安装vue-cli

         vue-cli可以帮助我们快速生成页面开发脚手架,cli2和cli3版本的区别可看:

         http://www.360doc.com/content/18/0809/12/35331283_776842375.shtml

         npm install -g vue-cli                -> cli版本2

         npm install -g @vue/cli             -> cli版本3

         文后使用的是cli2版本,如果安装cli3版本,如果也要vue-init创建项目,还需安装一个全局工具:npm install -g @vue/cli-init

         cli3安装如下:

         cli2会在用户这个目录生成如下脚本工具(cli3只有vue,而没有vue-init和vue-list):

         

            

    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:

var port = 3298;

var http = require('http');
var url = require('url');
var fs = require('fs');
var path = require('path');
var mine = require('./mine').types;
var connect = require('connect');
var history = require('connect-history-api-fallback');

function access(request, response, next) {
    var pathname = url.parse(request.url).pathname;
    if (pathname.indexOf("undefined")) {
        pathname = pathname.split("undefined").join("");
    }
    if (pathname=="/") {
        pathname = "/index.html";
    }

    var realPath = path.join("./", pathname);
    var ext = path.extname(realPath);
    ext = ext ? ext.slice(1) : 'unknown';

    fs.exists(realPath, function(exists) {
        if (!exists) {
            response.writeHead(404, {
                'Content-Type': 'text/plain'
            });
            response.write("Request URL " + pathname + " not found on this server.");
            response.end();
        }
        else {
            fs.readFile(realPath, "binary", function(err, file){
                if (err) {
                    response.writeHead(500, {
                        'Content-Type': 'text/plain'
                    });
                    response.end(err);
                }
                else {
                    var contentType = mine[ext] || "text/plain";
                    response.writeHead(200, {
                        'Content-Type': contentType
                    })
                    response.write(file, "binary");
                    response.end();
                }
            });
        }
    });
}

var app = connect().use(history()).use(access);
http.Server(app).listen(port);
console.log("vue-test serve at port :" + port + '......');

    mine.js:

exports.types = {
    "css": "text/css",
    "gif": "image/gif",
    "html": "text/html",
    "ico": "image/x-icon",
    "jpeg": "image/jpeg",
    "jpg": "image/jpeg",
    "js": "text/javascript",
    "json": "application/json",
    "pdf": "application/pdf",
    "png": "image/png",
    "svg": "image/svg+xml",
    "swf": "application/x-shockwave-flash",
    "tiff": "image/tiff",
    "txt": "text/plain",
    "wav": "audio/x-wav",
    "wma": "audio/x-ms-wma",
    "wmv": "video/x-ms-wmv",
    "xml": "text/xml",
    "woff": "application/x-woff",
    "woff2": "application/x-woff2",
    "tff": "application/x-font-truetype",
    "otf": "application/x-font-opentype",
    "eot": "application/vnd.ms-fontobject"
};

 

   启动: pm2 start app.js

   

    //

    

        停止: pm2 stop app 

        删除:    pm2 delete app

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值