String “true” and “false” to boolean

前端 未结 13 827
青春惊慌失措
青春惊慌失措 2020-12-08 18:23

I have a Rails application and I\'m using jQuery to query my search view in the background. There are fields q (search term), start_date, end

13条回答
  •  挽巷
    挽巷 (楼主)
    2020-12-08 18:47

    ActiveRecord::Type::Boolean.new.type_cast_from_user does this according to Rails' internal mappings ConnectionAdapters::Column::TRUE_VALUES and ConnectionAdapters::Column::FALSE_VALUES:

    [3] pry(main)> ActiveRecord::Type::Boolean.new.type_cast_from_user("true")
    => true
    [4] pry(main)> ActiveRecord::Type::Boolean.new.type_cast_from_user("false")
    => false
    [5] pry(main)> ActiveRecord::Type::Boolean.new.type_cast_from_user("T")
    => true
    [6] pry(main)> ActiveRecord::Type::Boolean.new.type_cast_from_user("F")
    => false
    [7] pry(main)> ActiveRecord::Type::Boolean.new.type_cast_from_user("yes")
    DEPRECATION WARNING: You attempted to assign a value which is not explicitly `true` or `false` ("yes") to a boolean column. Currently this value casts to `false`. This will change to match Ruby's semantics, and will cast to `true` in Rails 5. If you would like to maintain the current behavior, you should explicitly handle the values you would like cast to `false`. (called from 
    at (pry):7) => false [8] pry(main)> ActiveRecord::Type::Boolean.new.type_cast_from_user("no") DEPRECATION WARNING: You attempted to assign a value which is not explicitly `true` or `false` ("no") to a boolean column. Currently this value casts to `false`. This will change to match Ruby's semantics, and will cast to `true` in Rails 5. If you would like to maintain the current behavior, you should explicitly handle the values you would like cast to `false`. (called from
    at (pry):8) => false

    So you could make your own to_b (or to_bool or to_boolean) method in an initializer like this:

    class String
      def to_b
        ActiveRecord::Type::Boolean.new.type_cast_from_user(self)
      end
    end
    

提交回复
热议问题