我有以下代码:
我的jobs.html.erb
<div class="alert alert-error" style="display: none;"></div>
<p><%= link_to t("jobs.index.buttons.similar_functions"), user_email_settings_path, :class => "nice medium blue button", :id => "saveAgent" %> <small id="agent-saved" style="font-size: 1em !important;display: none;"><%= t("jobs.index.saved_agent") %></small><br /></p>
在该页面中,我有以下脚本:
$("#saveAgent").on('click', function (event) {
event.preventDefault();
$("#saveAgent").addClass("disabled");
if( $("#saveAgent").hasClass("disabled")) {
$.ajax({
type: 'POST',
url: $(this).attr("href"),
data: $("form").serialize(),
complete: function() {
$("#agent-saved").show(1).delay(20000).fadeOut(800);
$("#saveAgent").removeClass("disabled");
alert("<%= flash[:error] %>");
$('div.alert').show();
$('div.alert').text("<%= flash[:error] %>");
}
});
}
});
link_to转到我的email-settings_controller.rb,其中包含以下代码:
def create
api_params = params[:criteria]
api_params = params[:criteria].reject{|k,v| v.to_s.blank?}
@j = JobAgent.new(name_for_job_agent(current_user), true, api_params)
result = Sap.submit_job_agent(@j.name, @j.to_xml, api_params_for_user)
parser = MessageParser.new(result.body["RESULT"])
parser.messages.each do |message|
if message.type = "E"
flash[:error] = "test"
respond_to do |format|
format.json { render :json => flash}
end
end
end
end
现在因为它是ajax我无法以正常的方式渲染我的闪光,我必须通过JSON传递一些东西。我有的代码似乎在50%的时间内工作,有时他会返回正确的“测试”,有时他什么都不返回。
这是正确的做法吗?我怎样才能让它100%工作。
谢谢!
编辑1:
我正在尝试以下内容:How to send simple json response in Rails?
def testme
respond_to do |format|
msg = { :status => "ok", :message => "Success!", :html => "<b>...</b>" }
format.json { render :json => msg } # don't do msg.to_json
end
end
但是如何在我的完整功能中阅读msg?
答案 0 :(得分:0)
使用flash[:error] = '...'
时,消息将在下一个请求中使用,因为此语法通常在redirect_to
之前使用。
在您的情况下,您需要立即收到消息,因为您正在使用render
,因此您应该使用:
flash.now[:error] = '...'
了解它的工作原理:http://guides.rubyonrails.org/action_controller_overview.html#the-flash
答案 1 :(得分:0)
我已经修好了,就像这改变了我的控制器:
respond_to do |format|
format.json { render :json =>{ :message => "Hello world"} }
end
并将我的脚本更改为:
$("#saveAgent").on('click', function (event) {
event.preventDefault();
$("#saveAgent").addClass("disabled");
if( $("#saveAgent").hasClass("disabled")) {
$.ajax({
type: 'POST',
url: $(this).attr("href"),
data: $("form").serialize(),
success: function(data) {
$("#agent-saved").show(1).delay(20000).fadeOut(800);
$("#saveAgent").removeClass("disabled");
if (data.message != "") {
$('.alert.alert-error').show();
$('.alert.alert-error').text(data.message);
}
}
});
}
});