这是我在加载页面时所包含的代码:
<script type="text/javascript">
function test() {
$.get('/login', function(data){
alert("test");
$('#flash_content').html("hi");
}, 'script');}
function test2(){
var jqxhr = $.get("/login", function(data) {
$('#flash_content').html(data);}, 'script')
.success(function() { alert("second success"); })
.error(function(request, status,error) { alert(error); })
.complete(function() { alert("complete"); });}
$(document).ready(function() {
$("#login").click(function(event){
event.preventDefault(); // Prevent link from following its href
test2();
});});
</script>
当我调用test2()时,我可以在我的rails服务器日志中看到它呈现它应该的视图,并且在firebug中我看到我从ajax获取的响应确实是我要覆盖到页面上的形式,但是页面上的内容实际上没有任我已经用字符串“hi”替换了“Data”,并确实将其放入页面中。如您所见,会弹出一个警告并告诉我:
SyntaxError: missing ; before statement
以下是我的登录控制器方法:
@user = User.new
respond_to do |format|
format.html { }
format.js {render :layout => false }
format.xml { head :ok }
end
以及应呈现的视图:
<%= form_tag user_sessions_path, :method => :post do %>
<div class="field">
<%= label_tag :username %><br />
<%= text_field_tag :username %>
</div>
<div class="field">
<%= label_tag :password %><br />
<%= password_field_tag :password %></br>
Remember me : <%= check_box_tag :remember %>
</div>
<div class="actions">
<%= submit_tag "Login" %>
</div>
<% end %>
我已经在这里工作了几个小时,所以也许我没有看到明显的东西:(谢谢。
答案 0 :(得分:1)
你告诉jquery返回的是javascript($.get
的最后一个参数)。这告诉jquery当它得到你的响应时它应该对它进行评估。
但是你的回复是html - 试图评估一下,因为javascript没有意义。您应该省略该参数(让jquery猜测)或将其设置为'html'。
Rails仍然会将format.js
块用于xhr请求,但我相信您需要将其放在format.html
版本之前。