Generate JSON objects with a Builder-style DSL, inspired by jbuilder (https://github.com/rails/jbuilder)
- 
Add the dependency to your shard.yml:dependencies: jbuilder: github: shootingfly/jbuilder 
- 
Run shards install
require "jbuilder"First, write down the code.
Jbuilder.new do |json|
  json.null nil
  json.code 200
  json.msg "ok"
  json.merge!({"code" => 201})
  json.array! "array1", [1, 1.0, "1"]
  json.array!("array2", [1, 2, 3, 4]) do |json, item|
    json.code item
  end
  json.data do |json|
    json.code 400
    json.array! "array3", [1, 1.0, "1"]
  end
  json.set!("custom_field", %w[1 2])
end.to_jsonThen you can see,
{
  "null":null,
  "code":201,
  "msg":"ok",
  "array1":[
    1,
    1.0,
    "1"
  ],
  "array2":[
    {
      "code":1
    },
    {
      "code":2
    },
    {
      "code":3
    },
    {
      "code":4
    }
  ],
  "data":{
    "code":400,
    "array3":[
      1,
      1.0,
      "1"
    ]
  },
  "custom_field":[
    "1",
    "2"
  ]
}https://github.com/shootingfly/kemal-jbuilder-example
- v1.0.0
- Support Crystal 1.0.0
 
- v0.3.0
- Support Tuple and Named Tuple
- Support render with layout and child template
 
- v0.2.0
- Support Kilt
 
- v0.1.0
- First Release
 
- Fork it (https://github.com/shootingfly/jbuilder/fork)
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
- Shooting Fly - creator and maintainer