답변:
ActiveModel :: Dirty를 확인하십시오 (기본적으로 모든 모델에서 사용 가능). 설명서는 정말 좋지만 다음과 같은 작업을 수행 할 수 있습니다.
@user.street1_changed? # => true/false
이것이 여러 속성의 변경 사항을 확인하는 문제를 해결 한 방법입니다.
attrs = ["street1", "street2", "city", "state", "zipcode"]
if (@user.changed & attrs).any?
then do something....
end
이 changed
메소드는 해당 오브젝트에 대해 변경된 속성의 배열을 리턴합니다.
모두 @user.changed
와 attrs
내가 교회법을 얻을 수 있도록 배열이다 (참조 ary & other ary
방법). 교집합의 결과는 배열입니다. any?
배열 을 호출 하면 적어도 하나의 교차점이 있으면 사실입니다.
또한이 changed_attributes
메소드는 원래 값으로 속성의 해시를 반환하고 원래 값 changes
과 새 값으로 배열의 해시를 반환합니다.
이 메소드를 지원하는 버전에 대한 APIDock을 확인할 수 있습니다.
if attrs.any?{|attr| @user.send("#{attr}_changed?")}
여러 가지 속성 중 하나가 변경되었는지 확인하고 싶을 때-물론, 사용자 매개 변수를 send
메소드에 던지는 것을 좋아하지 않기 때문에 내가 정의한 속성 만 사용 하여이 작업을 수행합니다 . ;)
ActiveModel::Dirty
@model.update_attributes()
변경 사항을 숨겨서 나를 위해 작동하지 않았습니다 . 그래서 이것은 update
컨트롤러 의 메소드에서 변경 사항을 감지 한 방법입니다.
def update
@model = Model.find(params[:id])
detect_changes
if @model.update_attributes(params[:model])
do_stuff if attr_changed?
end
end
private
def detect_changes
@changed = []
@changed << :attr if @model.attr != params[:model][:attr]
end
def attr_changed?
@changed.include :attr
end
많은 속성 변경을 감지하려고하면 지저분해질 수 있습니다. 아마도 컨트롤러 에서이 작업을 수행해서는 안되지만 meh.
previous_changes
기본적으로 사용 가능한 이 작업을 수행 할 수 있습니다 .
#update_attributes
변경 사항을 숨기지 않습니다. 레코드를 저장하므로 모델이 업데이트되고 변경 사항이 없습니다. 모델에서 필드를 변경하고 changed?
저장하기 전에 확인 해야합니다. 즉. @ model.field = 'foo'또는@model.attributes = @model.attributes.merge(params[:model])
위의 답변이 더 좋지만 지식에 대해서는 또 다른 접근 방식이 있습니다 .'catagory '열 값을 객체 (@design)에 대해 변경하도록하십시오.
@design.changes.has_key?('catagory')
.changes는 키를 열 이름으로, 값을 각 열에 대해 두 개의 값 [old_value, new_value]을 갖는 배열로 해시를 반환합니다. 예를 들어 위의 카테고리는 @design의 'ABC'에서 'XYZ'로 변경되었습니다.
@design.changes # => {}
@design.catagory = 'XYZ'
@design.changes # => { 'catagory' => ['ABC', 'XYZ'] }