原文地址:https://adonis-china.org/posts/2前端
用Laravel也有些时日了,各类代码生成工具,各类Eloquent关联操做,各类微信、支付插件,再配合Larvel-admin扩展写后台简直爽到飞起。但总以为PHP+Javascript还不够优雅,因此最近折腾了一下AdonisJs - 一个NodeJs版的Laravel。node
其实好久以前也尝试过MEAN和Sails,但因为Laravel的思想根深蒂固,老是对她们提不起兴趣。并且NodeJs的市场本就鱼龙混杂,每一个框架都有本身的思想,因此一直在寻找Laravel的Node实现,因而就和AdonisJs结下了不解之缘。ios
相比PHP,在全栈开发方面NodeJs有自然优点web
都是用npm
安装扩展,与前端编程语言统一(废话)数据库
有些库先后端均可以用(如:axios、underscore)npm
环境更简单:一台新机器下个NodeJs,设置个淘宝镜像就OK了,其余不少命令行工具均可以用npm装编程
“天下大势,合久必分,分久必合”,因此发现趋势很重要axios
PC和移动端浏览器从最初的百花齐放到如今webkit一家独大windows
移动APP在不少场景已经被混合模式APP统一,如今几乎很难见到一款彻底原生不带H5的APP了后端
NW.js的没落和Electron的兴起再次让js在桌面端站稳脚跟
连桌面端Linux都几乎被Ubuntu统一了
JavaScript能作服务端、WEB端、桌面端和APP客户端,但世界上最好的PHP却力不从心。
和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项目就启动起来了,浏览器访问一下看看
额,这是我本身发明的一个词。我以为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的 多态关联
赶忙去试试吧,有任何问题均可以直接回复。