Adonis China:我为什么选择了AdonisJs
原文地址: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的 多态关联
好啦
赶紧去试试吧,有任何问题都可以直接回复。