原文地址:https://adonis-china.org/posts/2
前言
用Laravel也有些時(shí)日了,各種代碼生成工具,各種Eloquent關(guān)聯(lián)操作,各種微信、支付插件,再配合Larvel-admin擴(kuò)展寫(xiě)后臺(tái)簡(jiǎn)直爽到飛起。但總覺(jué)得PHP+Javascript還不夠優(yōu)雅,所以最近折騰了一下AdonisJs - 一個(gè)NodeJs版的Laravel。
其實(shí)很久之前也嘗試過(guò)MEAN和Sails,但由于Laravel的思想根深蒂固,總是對(duì)她們提不起興趣。而且NodeJs的市場(chǎng)本就魚(yú)龍混雜,每個(gè)框架都有自己的思想,所以一直在尋找Laravel的Node實(shí)現(xiàn),于是就和AdonisJs結(jié)下了不解之緣。
JavaScript相比PHP的優(yōu)勢(shì)
相比PHP,在全棧開(kāi)發(fā)方面NodeJs有天然優(yōu)勢(shì)
- 都是用
npm
安裝擴(kuò)展,與前端編程語(yǔ)言統(tǒng)一(廢話) - 有些庫(kù)前后端都可以用(如:axios、underscore)
- 環(huán)境更簡(jiǎn)單:一臺(tái)新機(jī)器下個(gè)NodeJs,設(shè)置個(gè)淘寶鏡像就OK了,其他很多命令行工具都可以用npm裝
- “天下大勢(shì),合久必分,分久必合”,所以發(fā)現(xiàn)趨勢(shì)很重要
- PC和移動(dòng)端瀏覽器從最初的百花齊放到現(xiàn)在webkit一家獨(dú)大
- 移動(dòng)APP在很多場(chǎng)景已經(jīng)被混合模式APP統(tǒng)一,現(xiàn)在幾乎很難見(jiàn)到一款完全原生不帶H5的APP了
- NW.js的沒(méi)落和Electron的興起再次讓js在桌面端站穩(wěn)腳跟
- 連桌面端Linux都幾乎被Ubuntu統(tǒng)一了
- JavaScript能做服務(wù)端、WEB端、桌面端和APP客戶端,但世界上最好的PHP卻力不從心。
AdonisJs的優(yōu)勢(shì)
- 和Laravel完全一致的思路,從邏輯上和代碼上都可以從Laravel平滑遷移。這對(duì)以后的擴(kuò)展、插件等周邊完善非常重要!
- 相比MEAN、Express、Koa等框架來(lái)說(shuō),AdonisJs是一整套解決方案,不會(huì)有東拼西湊的感覺(jué)。而且流程清晰,思路規(guī)范,更適合小規(guī)模企業(yè)級(jí)開(kāi)發(fā)。
- 相比meteor、sailsJs等其他真正的“全?!笨蚣軄?lái)講,AdonisJs類(lèi)似VueJs一樣是漸進(jìn)式的。自由度高,入門(mén)更簡(jiǎn)單,在現(xiàn)有的情況下遷移成本更低。
- 代碼生成、ORM、路由、JWT、WebSocket都很方便。
起步
安裝
npm i -g adonis-cli
adonis new blog --skip-install
cd blog
cnpm install
npm run serve:dev
就這樣,你的第一個(gè)adonisjs項(xiàng)目就啟動(dòng)起來(lái)了,瀏覽器訪問(wèn)一下看看
RMVC (路由-模型-視圖-控制器)
額,這是我自己發(fā)明的一個(gè)詞。我覺(jué)得MVC模式里路由也很重要,所以就自己加了個(gè)R。
路由
app/Http/routes.js
里面的路由跟Laravel幾乎一樣。支持直接寫(xiě)邏輯和指向一個(gè)Controller的方法
需要注意的是不支持參數(shù)的注入;如果是渲染視圖,需要加個(gè)yield
const Route = use('Route')
Route.get('users/:id', function * (request, response) {
const id = request.param('id')
response.send(`耶, 我得到了一個(gè)動(dòng)態(tài)ID: ${id}`)
})
Route.group('version1', function () {
Route.get('users', function * (request, response) {
// ...
})
}).prefix('api/v1')
Route
.get('users/:id', 'UserController.show')
.as('profile')
Route.get('about', function * (request, response) {
yield response.sendView('about')
})
控制器
可以用類(lèi)似Laravel的artisan的一個(gè)命令 ace
,windows上需要用node ace
./ace make:controller Home
# 或
./ace make:controller User --resource
UserController:
const User = use('App/Model/User')
class UsersController {
* index (request, response) {
const users = yield User.all()
yield response.sendView('users', { users: users.toJSON() })
}
}
還是和Laravel很像,需要注意的是AdonisJs里面有個(gè)use
方法用來(lái)模擬PHP的use
,用于導(dǎo)入各種包和模型等等。Controller的方法要用生成器方法,幾乎所有的數(shù)據(jù)庫(kù)查詢(xún)都要用yield
,像上面說(shuō)的,渲染視圖也要用yield
。
視圖
命令生成視圖:
./ace make:view welcome
# create: resources/views/welcome.njk
模板語(yǔ)法用的類(lèi)似twig的nunjuncks,和Laravel的blade也很像
{% if user.age %}
You are {{ user.age }} years old.
{% endif %}
語(yǔ)法高亮
你需要在你的編輯器/IDE里面安裝nunjucks模板的語(yǔ)法高亮插件. 如果你的編輯器沒(méi)有nunjucks模板語(yǔ)法高亮插件, 你可以使用twig模板高亮插件代替.
模型
創(chuàng)建模型
./ace make:model User
# 或者直接生成遷移文件,-m也行
./ace make:model User --migration
生成的樣子:
app/Model/User.js
'use strict'
const Lucid = use('Lucid')
class User extends Lucid {
}
關(guān)鍵在于關(guān)聯(lián):
class Book extends Lucid {
chapters () {
return this.hasMany('App/Model/Chapter')
}
}
學(xué)過(guò)Laravel的可以無(wú)腦嘗試了。不過(guò)目前只支持到多對(duì)多的belongsToMany
,還不支持Laravel Eloquent的 多態(tài)關(guān)聯(lián)
好啦
趕緊去試試吧,有任何問(wèn)題都可以直接回復(fù)。