我为何选择了AdonisJs

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

前言

用Laravel也有些时日了,各类代码生成工具,各类Eloquent关联操做,各类微信、支付插件,再配合Larvel-admin扩展写后台简直爽到飞起。但总以为PHP+Javascript还不够优雅,因此最近折腾了一下AdonisJs - 一个NodeJs版的Laravel。node

其实好久以前也尝试过MEAN和Sails,但因为Laravel的思想根深蒂固,老是对她们提不起兴趣。并且NodeJs的市场本就鱼龙混杂,每一个框架都有本身的思想,因此一直在寻找Laravel的Node实现,因而就和AdonisJs结下了不解之缘。ios

JavaScript相比PHP的优点

相比PHP,在全栈开发方面NodeJs有自然优点web

  1. 都是用npm安装扩展,与前端编程语言统一(废话)数据库

  2. 有些库先后端均可以用(如:axios、underscore)npm

  3. 环境更简单:一台新机器下个NodeJs,设置个淘宝镜像就OK了,其余不少命令行工具均可以用npm装编程

  4. “天下大势,合久必分,分久必合”,因此发现趋势很重要axios

    1. PC和移动端浏览器从最初的百花齐放到如今webkit一家独大windows

    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的 多态关联

好啦

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

相关文章
相关标签/搜索