手动搭建 vue-cli 学习

【一】.初始化

npm init -y

【二】.添加基础文件包解析详细安装

  • 压缩模板并引入打包JS
html-webpack-plugin

功能:将模板页面,并将打包JS自动引入到模板页
语法:

const HtmlWebpackPlugin = require('html-webpack-plugin');
...
plugins:[
    new HtmlWebpackPlugin({ template:'./index.html' })
]
...
  • 解析css,css3
style-loader css-loader postcss-loader

自右至左读取 先css-loader 再style-loader
1.css-loader 负责解析 CSS 代码,主要是为了处理 CSS 中的依赖
2.style-loader 将 css-loader 解析的结果转变成 JS 代码,运行时动态插入 style 标签来让 CSS 代码生效

解析css3
1.将'postcss-loader' 放在 style-loader css-loader 右侧优先引入
2.为postcss-loader添加配置文件
postcss.config.js

module.exports={
    plugins:[
        require('autoprefixer')
    ]
}
  • 解析图片
file-loader url-loader

不能单独安装url-loader ,因为内部对file-loader存在依赖

  • 解析es6语法
babel-loader @babel/core @babel/preset-env -D
  • js代码压缩 (只在生产模式下使用,且需要BABEL编译ES5)
uglifyjs-webpack-plugin
npm install uglifyjs-webpack-plugin -D
  • 热更新
webpack webpack-cli webpack-dev-server

【三】.对webpack.config.js进行配置

  • 动态的获取开发环境
    通过对package.json中定义scripts命令
...
"scripts": {
  "dev": "webpack --env.development",
  "build": "webpack --env.production"
}
...

可以获取一个env键值对,如上面 npm run dev 情况,会在终端输出 development : true,这样就获取了开发状态
后续就可以对webpack做动态配置
在webapck.config.js中,导出形式从
module.exports = { ... } 固定对象形式 书写为 module.exports = function(){ ... }
这样可以在函数中,针对开发环境,return 不同的配置

代码:

const path = require('path');

const VueLoaderPlugin = require('vue-loader/lib/plugin');
//const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports= function(envmes,arg){
    let env = envmes || {};
    let modemes = "";
    //其他配置
    let configmes = {};

    if(env.development){
        console.log('开发模式');
        modemes = 'development';        
        configmes = {
            devtool:'source-map',
            plugins:[
                //new HtmlWebpackPlugin({ template:'./index.html' }),
                new VueLoaderPlugin()
            ]
        }
    }else if(env.production){
        console.log('生产模式');
        modemes = 'production';
        configmes = {
            plugins:[
                //new HtmlWebpackPlugin({ template:'./index.html' }),
                new VueLoaderPlugin()
            ]
        }
    };
    
    return {
        mode:modemes,//模式
        entry:'./index.js',//入口文件
        resolve:{
            alias:{
                "vue" : path.resolve(__dirname,"node_modules/vue/dist/vue.esm")
            }
        },
        output:{
            path:path.resolve(__dirname,'build/'),
            filename:'bundle.min.js'
        },
        module:{
            rules:[
                {test:/\.css$/,use:['vue-style-loader','css-loader','postcss-loader']},
                {test:/\.(jpg|png|gif)$/i,use:{
                        loader:'url-loader',
                        options:{
                            outputPath:'image/',
                            limit:10*1024   //单位字节,例:10kb    -- 一般32
                        }
                    }
                },{
                    test:/\.jsx?/i,
                    exclude:/node_modules/,  //如果引入了node_modules中的包,不要编译
                    use:{
                        loader:'babel-loader',
                        options:{
                            presets:['@babel/preset-env']
                        }
                    }
                },{
                    test:/\.vue$/i,use:{loader:'vue-loader'}
                }
            ]
        },
        ...configmes
    };
}

1.解构可以将configmes配置变量,解构到最终返回配置中
错误!!!!!!!!!
节后修改:
------( 还是将配置分离出去 在配置一级目录引用 ) 解构有问题,
------(另外env 还是通过 process.env.NODE_ENV 来设置与获取,更符合行规)

2.利用resolve的alias别名,方便快速定义文件路径

【四】.针对vue本身

  • 安装vue环境
    npm install vue -S

在入口文件(如 index.js)中,引入vue
值得注意的是

import Vue from 'vue' ;  

会报错,原因是路径错误
You are using the runtime-only build of Vue where the template compiler is not available.
Either pre-compile the templates into render functions, or use the compiler-included build.

真实地址是

import Vue from 'vue/dist/vue.esm.js'

【五】.解析Vue中的单文件组件(xxx.vue)

  • 安装额外解析文件包
    1.针对.vue 格式解析
    安装 vue
    安装 vue-loader

2.解析单文件组件中css,并将css打包
安装 vue-style-loader

3.解析单文件组件中的template
安装 vue-html-loader

4.安装 vue-template-compiler
编译 整个单文件组件

安装:

npm install vue-loader vue-style-loader vue-html-loader vue-template-compiler -D
  • 对webpack.config.js配置:
    1.添加规则,解析.vue文件
    {
    test:/.vue$/i,use:{loader:'vue-loader'}
    }

2.修改css解析器
style-loader 更换为 vue-style-loader

3.配置 vue-loader/lib/plugin
引入

const VueLoaderPlugin = require('vue-loader/lib/plugin');
...
plugins:[
    new VueLoaderPlugin()
]
...

【六】.vue-router
安装:

npm install vue-router -S

路由使用暂无其他注意事项,同vue-cli

【七】.安装 数据请求
安装:
axios

npm install axios vue-axios -S;

vue-resource、fetch等
具体操作

【八】.vuex 数据管理
安装:

npm install vuex -S

具体操作

//-------------------------------【目前状态】
1.可以解析js es6 css css3 img 文件格式(后续可以自己添加对不同格式解析,如less等)
2.可以根据package.json自定义命令,动态配置打包(webpage)项目
3.可以解析单文件组件(xxx.vue)
4.使用路由 vue-router
5.数据请求 axios 、vue-resource 、fetch
6.组件状态(数据)管理 vuex

未完待续...

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,723评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,080评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,604评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,440评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,431评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,499评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,893评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,541评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,751评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,547评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,619评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,320评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,890评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,896评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,137评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,796评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,335评论 2 342

推荐阅读更多精彩内容

  • webpack 是什么? 本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(mo...
    IT老马阅读 3,299评论 2 27
  • 1. 新建一个文件夹,命名为 webpack-cli , webpack-cli 就是你的项目名,项目名建议使用小...
    鲁大师666阅读 1,459评论 1 3
  • 熟悉 webpack 与 webpack4 配置。 webpack4 相对于 3 的最主要的区别是所谓的零配置,但...
    yichen_china阅读 1,399评论 0 3
  • 黑白之间的教育 白夜私语45 493 “冬天来了,春天还会远吗?” 在很多事情上,我不觉得春天会不期而至,因为冬天...
    你不懂夜的黑阅读 677评论 2 25
  • 刚听完天气预报,明天还有雷阵雨。好几年没下雨这么勤了。 今天早上起来,向窗外望去,不用望天空,看外面...
    大鹏展翅阅读 594评论 9 24