0

鉴于:

<%=form_for [:project, @note], :remote => true do |f| %>

我想创建一个每隔几秒自动保存的 jquery 绑定。我不担心时间部分,只是如何使用jquery自动提交表单(即,不是用户点击提交按钮。)

我试过这个,但它不工作。建议?

$('form[data-remote]').live('submit', function (e) {
    alert(1);
    e.preventDefault();
});

谢谢!

4

4 回答 4

4

所以你说的是自动保存之类的东西,对吧?

也许您想为此指定一个 Javascript 间隔。一个例子可能是:

var autosave = window.setInterval("autosaveForm()", 1000);

function autosaveForm() {
  $('form[data-remote]').submit();
}

autosaveForm()这样做是每秒调用一次并提交表单。要停止自动保存,您可以clearInterval像这样使用:

window.clearInterval(autosave);

我希望这有帮助。

于 2010-10-25T22:45:23.177 回答
2

$('form[data-remote]').submit()将提交表格。

于 2010-10-25T22:38:18.420 回答
0

从 setInterval 开始:

  setInterval(transmit, 3000);

调用此函数:

function transmit(){
 // get the form field data
 var params = {
   formField1:$("input#formField1").val(),
   formField2:$("input#formField2").val()
 }

 // make the ajax call
 var url = "/controller/action";
   $.post(url, params,
     function(response, status){
     //display results(response, status);
   });
}
于 2010-10-25T23:16:34.937 回答
0

您使用的是什么版本的 jQuery?你用的是IE吗?早期版本的 live() 不适用于 IE 提交表单。(见http://github.com/rails/jquery-ujs/issues/issue/8

我想我最终使用了这个:

if (jQuery.browser.msie){
    $("form[data-remote]").delegate("input[type='submit'],button[type='submit'],input[name='commit']", 'click', function(e) {
        $(this).parents("form[data-remote]").submit();
        if(e.preventDefault) e.preventDefault();
    });
}

在一个项目中。

于 2010-10-26T02:03:49.840 回答