全栈之巅

Adonis China:我为什么选择了AdonisJs

2017-04-26  本文已影响45人  全栈之巅Johnny

原文地址: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. “天下大势,合久必分,分久必合”,所以发现趋势很重要
  5. PC和移动端浏览器从最初的百花齐放到现在webkit一家独大
  6. 移动APP在很多场景已经被混合模式APP统一,现在几乎很难见到一款完全原生不带H5的APP了
  7. NW.js的没落和Electron的兴起再次让js在桌面端站稳脚跟
  8. 连桌面端Linux都几乎被Ubuntu统一了
  9. 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的 多态关联

好啦

赶紧去试试吧,有任何问题都可以直接回复。

上一篇下一篇

猜你喜欢

热点阅读