我為什么選擇了AdonisJs

原文地址:https://adonis-china.org/posts/2

前言

用Laravel也有些時(shí)日了,各種代碼生成工具,各種Eloquent關(guān)聯(lián)操作,各種微信、支付插件,再配合Larvel-admin擴(kuò)展寫后臺(tái)簡(jiǎn)直爽到飛起。但總覺得PHP+Javascript還不夠優(yōu)雅,所以最近折騰了一下AdonisJs - 一個(gè)NodeJs版的Laravel。

其實(shí)很久之前也嘗試過MEAN和Sails,但由于Laravel的思想根深蒂固,總是對(duì)她們提不起興趣。而且NodeJs的市場(chǎng)本就魚龍混雜,每個(gè)框架都有自己的思想,所以一直在尋找Laravel的Node實(shí)現(xiàn),于是就和AdonisJs結(jié)下了不解之緣。

JavaScript相比PHP的優(yōu)勢(shì)

相比PHP,在全棧開發(fā)方面NodeJs有天然優(yōu)勢(shì)

  1. 都是用npm安裝擴(kuò)展,與前端編程語(yǔ)言統(tǒng)一(廢話)
  2. 有些庫(kù)前后端都可以用(如:axios、underscore)
  3. 環(huán)境更簡(jiǎn)單:一臺(tái)新機(jī)器下個(gè)NodeJs,設(shè)置個(gè)淘寶鏡像就OK了,其他很多命令行工具都可以用npm裝
  4. “天下大勢(shì),合久必分,分久必合”,所以發(fā)現(xiàn)趨勢(shì)很重要
  5. PC和移動(dòng)端瀏覽器從最初的百花齊放到現(xiàn)在webkit一家獨(dú)大
  6. 移動(dòng)APP在很多場(chǎng)景已經(jīng)被混合模式APP統(tǒng)一,現(xiàn)在幾乎很難見到一款完全原生不帶H5的APP了
  7. NW.js的沒落和Electron的興起再次讓js在桌面端站穩(wěn)腳跟
  8. 連桌面端Linux都幾乎被Ubuntu統(tǒng)一了
  9. JavaScript能做服務(wù)端、WEB端、桌面端和APP客戶端,但世界上最好的PHP卻力不從心。

AdonisJs的優(yōu)勢(shì)

  1. 和Laravel完全一致的思路,從邏輯上和代碼上都可以從Laravel平滑遷移。這對(duì)以后的擴(kuò)展、插件等周邊完善非常重要!
  2. 相比MEAN、Express、Koa等框架來說,AdonisJs是一整套解決方案,不會(huì)有東拼西湊的感覺。而且流程清晰,思路規(guī)范,更適合小規(guī)模企業(yè)級(jí)開發(fā)。
  3. 相比meteor、sailsJs等其他真正的“全?!笨蚣軄碇v,AdonisJs類似VueJs一樣是漸進(jìn)式的。自由度高,入門更簡(jiǎn)單,在現(xiàn)有的情況下遷移成本更低。
  4. 代碼生成、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)起來了,瀏覽器訪問一下看看

RMVC (路由-模型-視圖-控制器)

額,這是我自己發(fā)明的一個(gè)詞。我覺得MVC模式里路由也很重要,所以就自己加了個(gè)R。

路由

app/Http/routes.js 里面的路由跟Laravel幾乎一樣。支持直接寫邏輯和指向一個(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')
})

控制器

可以用類似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方法用來模擬PHP的use,用于導(dǎo)入各種包和模型等等。Controller的方法要用生成器方法,幾乎所有的數(shù)據(jù)庫(kù)查詢都要用yield,像上面說的,渲染視圖也要用yield

視圖

命令生成視圖:

./ace make:view welcome

# create: resources/views/welcome.njk

模板語(yǔ)法用的類似twig的nunjuncks,和Laravel的blade也很像

{% if user.age %}
  You are {{ user.age }} years old.
{% endif %}

語(yǔ)法高亮

你需要在你的編輯器/IDE里面安裝nunjucks模板的語(yǔ)法高亮插件. 如果你的編輯器沒有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é)過Laravel的可以無腦嘗試了。不過目前只支持到多對(duì)多的belongsToMany,還不支持Laravel Eloquent的 多態(tài)關(guān)聯(lián)

好啦

趕緊去試試吧,有任何問題都可以直接回復(fù)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,501評(píng)論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,673評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,610評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,939評(píng)論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,668評(píng)論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,004評(píng)論 1 329
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,001評(píng)論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,173評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,705評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,426評(píng)論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,656評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,139評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,833評(píng)論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,247評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,580評(píng)論 1 295
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,371評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,621評(píng)論 2 380

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

  • 原文地址:https://adonis-china.org/posts/2 前言 用Laravel也有些時(shí)日了,各...
    全棧之巔Johnny閱讀 804評(píng)論 0 0
  • 原文鏈接 必備品 文檔:Documentation API:API Reference 視頻:Laracasts ...
    layjoy閱讀 8,619評(píng)論 0 121
  • 必備品文檔:DocumentationAPI: API Reference視頻:Laracasts速查表:Lara...
    ethanzhang閱讀 5,759評(píng)論 0 68
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,829評(píng)論 18 139
  • 1、感恩今天的天氣,降溫了,又有臺(tái)風(fēng)襲來。外面風(fēng)雨交加,心里卻很安穩(wěn)。 2、感恩醫(yī)院,妹妹感冒發(fā)燒第二天,今天需要...
    感恩女神詩(shī)淘閱讀 302評(píng)論 0 0