原文地址:https://adonis-china.org/posts/2
前言
用Laravel也有些時日了,各種程式碼生成工具,各種Eloquent關聯操作,各種微信、支付外掛,再配合Larvel-admin擴充套件寫後臺簡直爽到飛起。但總覺得PHP+Javascript還不夠優雅,所以最近折騰了一下AdonisJs - 一個NodeJs版的Laravel。
其實很久之前也嘗試過MEAN和Sails,但由於Laravel的思想根深蒂固,總是對她們提不起興趣。而且NodeJs的市場本就魚龍混雜,每個框架都有自己的思想,所以一直在尋找Laravel的Node實現,於是就和AdonisJs結下了不解之緣。
JavaScript相比PHP的優勢
相比PHP,在全棧開發方面NodeJs有天然優勢
- 都是用
npm
安裝擴充套件,與前端程式語言統一(廢話) - 有些庫前後端都可以用(如:axios、underscore)
- 環境更簡單:一臺新機器下個NodeJs,設定個淘寶映象就OK了,其他很多命令列工具都可以用npm裝
- “天下大勢,合久必分,分久必合”,所以發現趨勢很重要
- PC和移動端瀏覽器從最初的百花齊放到現在webkit一家獨大
- 移動APP在很多場景已經被混合模式APP統一,現在幾乎很難見到一款完全原生不帶H5的APP了
- NW.js的沒落和Electron的興起再次讓js在桌面端站穩腳跟
- 連桌面端Linux都幾乎被Ubuntu統一了
- JavaScript能做服務端、WEB端、桌面端和APP客戶端,但世界上最好的PHP卻力不從心。
AdonisJs的優勢
- 和Laravel完全一致的思路,從邏輯上和程式碼上都可以從Laravel平滑遷移。這對以後的擴充套件、外掛等周邊完善非常重要!
- 相比MEAN、Express、Koa等框架來說,AdonisJs是一整套解決方案,不會有東拼西湊的感覺。而且流程清晰,思路規範,更適合小規模企業級開發。
- 相比meteor、sailsJs等其他真正的“全棧”框架來講,AdonisJs類似VueJs一樣是漸進式的。自由度高,入門更簡單,在現有的情況下遷移成本更低。
- 程式碼生成、ORM、路由、JWT、WebSocket都很方便。
起步
安裝
npm i -g adonis-cli
adonis new blog --skip-install
cd blog
cnpm install
npm run serve:dev
就這樣,你的第一個adonisjs專案就啟動起來了,瀏覽器訪問一下看看
RMVC (路由-模型-檢視-控制器)
額,這是我自己發明的一個詞。我覺得MVC模式里路由也很重要,所以就自己加了個R。
路由
app/Http/routes.js
裡面的路由跟Laravel幾乎一樣。支援直接寫邏輯和指向一個Controller的方法
需要注意的是不支援引數的注入;如果是渲染檢視,需要加個yield
const Route = use('Route')
Route.get('users/:id', function * (request, response) {
const id = request.param('id')
response.send(`耶, 我得到了一個動態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')
})
控制器
可以用類似Laravel的artisan的一個命令 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裡面有個use
方法用來模擬PHP的use
,用於匯入各種包和模型等等。Controller的方法要用生成器方法,幾乎所有的資料庫查詢都要用yield
,像上面說的,渲染檢視也要用yield
。
檢視
命令生成檢視:
./ace make:view welcome
# create: resources/views/welcome.njk
模板語法用的類似twig的nunjuncks,和Laravel的blade也很像
{% if user.age %}
You are {{ user.age }} years old.
{% endif %}
語法高亮
你需要在你的編輯器/IDE裡面安裝nunjucks模板的語法高亮外掛. 如果你的編輯器沒有nunjucks模板語法高亮外掛, 你可以使用twig模板高亮外掛代替.
模型
建立模型
./ace make:model User
# 或者直接生成遷移檔案,-m也行
./ace make:model User --migration
生成的樣子:
app/Model/User.js
'use strict'
const Lucid = use('Lucid')
class User extends Lucid {
}
關鍵在於關聯:
class Book extends Lucid {
chapters () {
return this.hasMany('App/Model/Chapter')
}
}
學過Laravel的可以無腦嘗試了。不過目前只支援到多對多的belongsToMany
,還不支援Laravel Eloquent的 多型關聯
好啦
趕緊去試試吧,有任何問題都可以直接回復。
本作品採用《CC 協議》,轉載必須註明作者和本文連結