我為什麼選擇了 AdonisJs

genyii發表於2017-04-25

原文地址: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有天然優勢

  1. 都是用npm安裝擴充套件,與前端程式語言統一(廢話)
  2. 有些庫前後端都可以用(如:axios、underscore)
  3. 環境更簡單:一臺新機器下個NodeJs,設定個淘寶映象就OK了,其他很多命令列工具都可以用npm裝
  4. “天下大勢,合久必分,分久必合”,所以發現趨勢很重要
    1. PC和移動端瀏覽器從最初的百花齊放到現在webkit一家獨大
    2. 移動APP在很多場景已經被混合模式APP統一,現在幾乎很難見到一款完全原生不帶H5的APP了
    3. NW.js的沒落和Electron的興起再次讓js在桌面端站穩腳跟
    4. 連桌面端Linux都幾乎被Ubuntu統一了
  5. JavaScript能做服務端、WEB端、桌面端和APP客戶端,但世界上最好的PHP卻力不從心。

AdonisJs的優勢

  1. 和Laravel完全一致的思路,從邏輯上和程式碼上都可以從Laravel平滑遷移。這對以後的擴充套件、外掛等周邊完善非常重要!
  2. 相比MEAN、Express、Koa等框架來說,AdonisJs是一整套解決方案,不會有東拼西湊的感覺。而且流程清晰,思路規範,更適合小規模企業級開發。
  3. 相比meteor、sailsJs等其他真正的“全棧”框架來講,AdonisJs類似VueJs一樣是漸進式的。自由度高,入門更簡單,在現有的情況下遷移成本更低。
  4. 程式碼生成、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 協議》,轉載必須註明作者和本文連結

相關文章