美文网首页全栈之巅
Adonis China:我为什么选择了AdonisJs

Adonis China:我为什么选择了AdonisJs

作者: 全栈之巅Johnny | 来源:发表于2017-04-26 11:18 被阅读45次

    原文地址: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的 多态关联

    好啦

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

    相关文章

      网友评论

        本文标题:Adonis China:我为什么选择了AdonisJs

        本文链接:https://www.haomeiwen.com/subject/worizttx.html