成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

webpack+vue+koa+mongoDB,從零開始搭建一個網(wǎng)站

高璐 / 1057人閱讀

摘要:地址的搭建新建項(xiàng)目文件夾初始化項(xiàng)目搭建的基本框架同時安裝依賴版本號的熱更新創(chuàng)建一個文件夾,創(chuàng)建一個文件測試能否打包,發(fā)現(xiàn)報錯缺少在文件里面的入口上面加上現(xiàn)在先是在本地跑起來,如果是生產(chǎn)環(huán)境的話,此時再進(jìn)行打包打包成功。

github 地址 https://github.com/wangxiaoxi...

webpakc+vue的搭建
1.新建項(xiàng)目文件夾(see-films);
2.npm init //初始化項(xiàng)目
3.搭建webpack的基本框架

const path = require("path");
const webpack = require("webpack");
module.exports = {
    entry:{
        entry:"./src/entry.js"
    },
    output:{
        path:path.resolve( __dirname,"dist" ),
        filename:"[name].js"
    },
    module:{

    },
    plugins:[

    ],
    devServer:{    
        
    }
};

同時安裝依賴

npm i -D webpack(版本號4.14.0)  
npm i -D webpack-cli 

4.webpack的熱更新

npm i -D webpack-dev-server 
devServer:{    
        contentBase:path.resolve( __dirname,"dist" ),
        host:"127.0.0.1",
        compress:true,
        port:9001
    }

創(chuàng)建一個src文件夾,創(chuàng)建一個entry.js文件測試能否打包,發(fā)現(xiàn)報錯 缺少mode
在webpacl.config.js文件里面的入口entry上面加上mode:"development",現(xiàn)在先是在本地跑起來,如果是生產(chǎn)環(huán)境的話mode:"production",此時再進(jìn)行打包----打包成功。第一步完成。

5.安裝模板文件依賴
npm i -D html-webpack-plugin
在webpack.config.js文件中的plugins中
plugins:[

    new htmlPlugin({
        minify:{
            removeAttributeQuotes:true
        },
        hash:true,
        template:"./src/index.html"
    })
]

在src文件夾下面創(chuàng)建index.html
然后webpack測試能否打包成功
此時的目錄結(jié)構(gòu)是這樣子的!

圖片描述

6.vue的搭建!!!

根目錄新建文件夾client
創(chuàng)建文件 main.js和App.vue
在根目錄創(chuàng)建index.html
然后修改webpack.config.js文件中的入口和plugin插件的模板

并安裝依賴
npm i -S vue
npm i -D vue-template-complier
npm i -D extract-text-webpack-plugin
npm i -D vue-loader vue-style-loader css-loader

此時的webpack.config.js是這樣的

const path = require("path");
const webpack = require("webpack");
const htmlPlugin = require("html-webpack-plugin");
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const VueLoaderPlugin = require("vue-loader/lib/plugin");
module.exports = {
    mode:"development",
    resolve: {
        extensions: [".js", ".vue", ".json"],
        alias: {
            "vue$": "vue/dist/vue.esm.js"
        }
    },
    entry:{
        entry:"./client/main.js",
        vue:"vue"
    },
    output:{
        path:path.resolve( __dirname,"dist" ),
        filename:"[name].js"
    },
    module:{
        rules:[
            {
                test: /.vue$/,
                loader: "vue-loader",
                options: {
                    loaders: {
                        css: ExtractTextPlugin.extract({
                            use: {loader: "css-loader"},
                            fallback: "vue-style-loader"
                        })
                    }
                }
            }
        ]
    },
    plugins:[
        new htmlPlugin({
            minify:{
                removeAttributeQuotes:true
            },
            hash:true,
            template:"./index.html"
        }),
        new VueLoaderPlugin(),
        new ExtractTextPlugin("css/index.css")
    ],
    devServer:{    
        contentBase:path.resolve( __dirname,"dist" ),
        host:"127.0.0.1",
        compress:true,
        port:9001
    }
};

到此處就是一個最基礎(chǔ)的vue架構(gòu);
此時的目錄結(jié)構(gòu)如下
圖片描述

看到這里,相信你也測試過,然后發(fā)現(xiàn)有個問題,就是在.vue文件里面的style中對樣式進(jìn)行修改會報錯,原因是webpack4.x版本得使用mini-css-extract-plugin代替原來的extract-text-webpack-plugin,修改之后如下

const path = require("path");
const webpack = require("webpack");
const htmlPlugin = require("html-webpack-plugin");
const VueLoaderPlugin = require("vue-loader/lib/plugin");
const MiniCssExtractPlugin = require("mini-css-extract-plugin");

module.exports = {
    devtool:"cheap-module-eval-source-map",
    mode:"development",
    resolve: {
        extensions: [".js", ".vue", ".json"],
        alias: {
            "vue$": "vue/dist/vue.esm.js"
        }
    },
    entry:{
        entry:"./client/main.js",
        vue:"vue"
    },
    output:{
        path:path.resolve( __dirname,"dist" ),
        filename:"[name].js",
        publicPath:"http://127.0.0.1:9001/"
    },
    module:{
        rules:[
            {
                test: /.js$/,
                use: "babel-loader",
                exclude: /node_modules/
            },
            {
                test: /.css$/,
                use:[
                    MiniCssExtractPlugin.loader,
                    {
                        loader: "css-loader?modules=false",
                        options: {
                            importLoaders: 1,
                            minimize: true
                        }
                    }
                ]
            },
            {
                test: /.vue$/,
                loader: "vue-loader"
            }
        ]
    },
    plugins:[
        new htmlPlugin({
            minify:{
                removeAttributeQuotes:true
            },
            hash:true,
            template:"./index.html"
        }),
        new VueLoaderPlugin(),
        new MiniCssExtractPlugin({
            filename: "[name].css",
            chunkFilename: "[id].css"
        })
    ],
    devServer:{    
        contentBase:path.resolve( __dirname,"dist" ),
        host:"127.0.0.1",
        compress:true,
        port:9001
    }
};

7.VUE熱更新

只需要安裝vue-hot-reload-api依賴 配合就能夠輕松實(shí)現(xiàn)。

8.VUE路由

安裝vue-router 然后修改main.js如下,并在同層目錄生成router.config.js,此時的就能根據(jù)你的喜好去建立路由了。

import Vue from "vue";
import App from "./App";

import VueRouter from "vue-router";
Vue.use(VueRouter);
import routes from "./router.config.js";
const router = new VueRouter({
    routes: routes
});

new Vue({
  el: "#app",
  router,
  components: { App },
  template: ""
})

9.KOA的引入和基礎(chǔ)測試

const Koa = require("koa");
const Rrouter = require("koa-router");
const cors = require("koa2-cors");

( async () => {
    const app = new Koa();
    
    app.use( cors() );
    
    const router = new Rrouter();
    router.get("/getFirstMessage",async ctx=>{
        ctx.body = {
            message:"get"
        } 
    });
    app.use(router.routes()).use(router.allowedMethods());
    app.listen(9001 ,async ()=>{
        console.log("CONNECTED")
    });
} )()

http://127.0.0.1:9001/getFirstMessage
此時就能夠通過接口拿到數(shù)據(jù)

10.改裝路由---使用裝飾器

在server文件夾下建立如上文件夾和文件

npm i -S babel-core babel-plugin-transform-decorators-legacy babel-polyfill ramda lodash babel-preset-stage-0

/*裝飾器注冊*/
require("babel-core/register")();
require("babel-polyfill");

const Koa = require("koa");

/*該方法用來批量引入中間件*/
const useMiddlewares = require("./lib/useMiddlewares");

( async () => {
    const app = new Koa();

    await useMiddlewares(app);

    app.listen(9001 ,async ()=>{
        console.log("CONNECTED")
    });
} )()

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/52560.html

相關(guān)文章

  • webpack+vue+koa+mongoDB,從零開始搭建一個網(wǎng)站

    摘要:地址的搭建新建項(xiàng)目文件夾初始化項(xiàng)目搭建的基本框架同時安裝依賴版本號的熱更新創(chuàng)建一個文件夾,創(chuàng)建一個文件測試能否打包,發(fā)現(xiàn)報錯缺少在文件里面的入口上面加上現(xiàn)在先是在本地跑起來,如果是生產(chǎn)環(huán)境的話,此時再進(jìn)行打包打包成功。 github 地址 https://github.com/wangxiaoxi... webpakc+vue的搭建1.新建項(xiàng)目文件夾(see-films);2.npm ...

    Java_oldboy 評論0 收藏0
  • webpack+vue+koa+mongoDB,從零開始搭建一個網(wǎng)站

    摘要:地址的搭建新建項(xiàng)目文件夾初始化項(xiàng)目搭建的基本框架同時安裝依賴版本號的熱更新創(chuàng)建一個文件夾,創(chuàng)建一個文件測試能否打包,發(fā)現(xiàn)報錯缺少在文件里面的入口上面加上現(xiàn)在先是在本地跑起來,如果是生產(chǎn)環(huán)境的話,此時再進(jìn)行打包打包成功。 github 地址 https://github.com/wangxiaoxi... webpakc+vue的搭建1.新建項(xiàng)目文件夾(see-films);2.npm ...

    xumenger 評論0 收藏0
  • 關(guān)于Vue2一些值得推薦的文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請點(diǎn)擊集前端最近很火的框架資源定時更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時更新,歡迎 Star 一下。 蘇...

    sutaking 評論0 收藏0

發(fā)表評論

0條評論

高璐

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<