Class: BigDecimal

Inherits:
Object show all
Includes:
ActiveSupport::BigDecimalWithDefaultFormat, ActiveSupport::DeprecatedNumericWithFormat, ActiveSupport::NumericWithFormat
Defined in:
activesupport/lib/active_support/core_ext/object/json.rb

Instance Method Summary collapse

Methods included from ActiveSupport::NumericWithFormat

#to_fs

Methods included from ActiveSupport::BigDecimalWithDefaultFormat

#to_s

Methods included from ActiveSupport::DeprecatedNumericWithFormat

#to_s

Instance Method Details

#as_json(options = nil) ⇒ Object

A BigDecimal would be naturally represented as a JSON number. Most libraries, however, parse non-integer JSON numbers directly as floats. Clients using those libraries would get in general a wrong number and no way to recover other than manually inspecting the string with the JSON code itself.

That's why a JSON string is returned. The JSON literal is not numeric, but if the other end knows by contract that the data is supposed to be a BigDecimal, it still has the chance to post-process the string and get the real value.


128
129
130
# File 'activesupport/lib/active_support/core_ext/object/json.rb', line 128

def as_json(options = nil) # :nodoc:
  finite? ? to_s : nil
end