使用Vue語法渲染你的Koa視圖文件?

前言

Koa是Express團隊開發(fā)新一代Node Web應用開發(fā)框架港粱,當你使用她開發(fā)你的Web應用時螃成,一件很重要的事肯定就是——怎樣渲染我的視圖?

很多人想查坪,那還不簡單寸宏,選擇一個模板引擎,再找個對應支持該引擎的Koa中間件不就行了偿曙;
答案是這樣的氮凝,你也能找到類似下面一堆的中間件:

koa views.png

但是有沒有想過,直接用Vue的語法與渲染你的視圖望忆?于是你找了很多地方罩阵,你并不一定找到很好的方案,找到更多的也許是Vue ssr集成方案上去了启摄,但是那個有很多麻煩的地方稿壁,它的比較好的使用場景是前后端同構開發(fā);

而你現(xiàn)在只想簡單的歉备,要Vue的語法傅是,和他的一些其他核心特性,如:組件化、指令喧笔、過濾器等帽驯;有沒有這樣一個現(xiàn)成Koa中間件?

有J檎ⅰD岜洹!

合適的中間件

正是因為我有上面的需求梗劫,同時也沒有找到類似的解決方案享甸,所以我自己基于Vue的服務端渲染方案封裝了一個Koa中間件,可以實現(xiàn)上面的所有需求梳侨,她的地址:

https://github.com/imingyu/koa-vue-view

可以查看git倉庫中test文件夾蛉威,里面涉及了場景需求的單元測試,均已通過走哺,可以放心使用

此中間件目前支持Koa2版本蚯嫌,最近我會更新下,讓她也支持Koa1丙躏;

安裝

npm i -S koa-vue-view

使用

<!--模板: ./views/Master.vue -->
<template>
    <html lang="zh-CN">

    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>{{hight(app.name)}} - {{app.version}}</title>
        <slot name="meta"></slot>
    </head>

    <body>
        <h1>{{layoutName}} - {{layoutVersion}}</h1>
        <slot name="top"></slot>
        <slot></slot>
        <slot name="bottom"></slot>
    </body>

    </html>
</template>

<!--組件: ./components/Age.vue -->
<template>
    <strong style="color:red;">
        <slot></slot>
    </strong>
</template>


<!--頁面: ./views/User.vue -->
<template>
    <Master>
        <ul>
            <li v-for="(item,index) in users" :key="index">{{item.name}} <Age>{{ add(item.age, 1) }}</Age></li>
        </ul>
    </Master>
</template>
var path = require('path');
var Koa = require('koa');
var VueView = require('koa-vue-view');

var app = new Koa();
app.use(VueView({
    methodName: 'render',//在koa ctx注冊渲染視圖的方法名择示,默認render
    data: {
        _: require('lodash'),
        app: {
            name: 'Github',
            version: '1.0.0'
        }
    },
    methods: {
        add(a, b) {
            return a + b;
        }
    },
    components: {
        Master: {
            path: path.resolve(__dirname, './views/Master.vue'),
            data() {
                this.layoutVersion = '1.0.0';
                return {
                    layoutName: 'master'
                }
            },
            methods: {
                hight(str) {
                    return `***${str}***`;
                }
            }
        },
        Age: path.resolve(__dirname, './components/Age.vue')
    }
}));

app.use(ctx => {
    ctx.state.users = [{
        name: 'Tom',
        age: 20
    }, {
        name: 'Alice',
        age: 18
    }];
    ctx.render(path.resolve(__dirname, './views/User.vue'));
    /*
    或者
    ctx.render({
        path:path.resolve(__dirname, './views/User.vue'),
        data(){
            return {name:'Github'}
        },
        methods:{
            show(){}
        }
    });
    */
})


app.listen(8200);

運行上述代碼后,你就會發(fā)現(xiàn)晒旅,哇塞Uっぁ! 可以在Koa視圖里歡快的玩耍Vue啦废恋,歐耶谈秫!

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市鱼鼓,隨后出現(xiàn)的幾起案子拟烫,更是在濱河造成了極大的恐慌,老刑警劉巖迄本,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件硕淑,死亡現(xiàn)場離奇詭異,居然都是意外死亡嘉赎,警方通過查閱死者的電腦和手機置媳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來曹阔,“玉大人半开,你說我怎么就攤上這事≡叻荩” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長抓韩。 經(jīng)常有香客問我纠永,道長,這世上最難降的妖魔是什么谒拴? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任尝江,我火速辦了婚禮,結果婚禮上英上,老公的妹妹穿的比我還像新娘炭序。我一直安慰自己,他們只是感情好苍日,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布惭聂。 她就那樣靜靜地躺著,像睡著了一般相恃。 火紅的嫁衣襯著肌膚如雪辜纲。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天拦耐,我揣著相機與錄音耕腾,去河邊找鬼。 笑死杀糯,一個胖子當著我的面吹牛扫俺,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播固翰,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼狼纬,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了倦挂?” 一聲冷哼從身側響起畸颅,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎方援,沒想到半個月后没炒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡犯戏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年送火,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片先匪。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡种吸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出呀非,到底是詐尸還是另有隱情坚俗,我是刑警寧澤镜盯,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站猖败,受9級特大地震影響速缆,放射性物質發(fā)生泄漏。R本人自食惡果不足惜恩闻,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一艺糜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧幢尚,春花似錦破停、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至边涕,卻和暖如春晤碘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背功蜓。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工园爷, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人式撼。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓童社,卻偏偏與公主長得像,于是被迫代替她去往敵國和親著隆。 傳聞我的和親對象是個殘疾皇子扰楼,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,079評論 25 707
  • 英專畢業(yè)六年了弦赖,如今又將重操英語,從翻譯做起浦辨,人生規(guī)劃真是呵呵噠蹬竖。計劃是陸續(xù)寫下我這段時間的經(jīng)驗和體會,紀念我逝去...
    靳冬閱讀 436評論 0 0
  • 今晚老爸的手藝失準流酬,魚蒸得未到火候币厕,有點腥。 再翻蒸芽腾,魚肉就韌旦装,跟嚼橡膠一樣。再粗鄙的漁夫也難下咽摊滔。 老人說舊時管...
    了不起的陸建木木閱讀 195評論 0 0
  • 以下分數(shù)均為個人意見。 泰國人嗜甜旱函,吃面條里面都要加糖O斐病C杼稀棒妨! 路邊街攤吃的 味道70分。 應該是泰式火鍋含长,不過就是...
    你是我心人閱讀 415評論 0 0