我有一个带有
我想要做的是使用jquery-ujs的事件系统在将请求发送到服务器之前附加数据。
类似于这样:
data-remote="true"
属性的Ajax表单,我正在将其提交到Rails中的控制器。我想要做的是使用jquery-ujs的事件系统在将请求发送到服务器之前附加数据。
类似于这样:
$("#my_form").bind('ajax:beforeSend', function(xhr, settings){
// serialize some object and append it
});
我无法弄清如何对数据进行标记?
编辑 这是控制台中“xhr”对象的样子。
f.Event
currentTarget: DOMWindow
data: undefined
exclusive: undefined
handleObj: Object
handler: function N(a){var b,c,d,e,g,h,i,j,k,l,m,n,o,p=[],q=[],r=f._data(this,"events");if(!(a.liveFired===this||!r||!r.live||a.target.disabled||a.button&&a.type==="click")){a.namespace&&(n=new RegExp("(^|\\.)"+a.namespace.split(".").join("\\.(?:.*\\.)?")+"(\\.|$)")),a.liveFired=this;var s=r.live.slice(0);for(i=0;i<s.length;i++)g=s[i],g.origType.replace(y,"")===a.type?q.push(g.selector):s.splice(i--,1);e=f(a.target).closest(q,a.currentTarget);for(j=0,k=e.length;j<k;j++){m=e[j];for(i=0;i<s.length;i++){g=s[i];if(m.selector===g.selector&&(!n||n.test(g.namespace))&&!m.elem.disabled){h=m.elem,d=null;if(g.preType==="mouseenter"||g.preType==="mouseleave")a.type=g.preType,d=f(a.relatedTarget).closest(g.selector)[0],d&&f.contains(h,d)&&(d=h);(!d||d!==h)&&p.push({elem:h,handleObj:g,level:m.level})}}}for(j=0,k=p.length;j<k;j++){e=p[j];if(c&&e.level>c)break;a.currentTarget=e.elem,a.data=e.handleObj.data,a.handleObj=e.handleObj,o=e.handleObj.origHandler.apply(e.elem,arguments);if(o===!1||a.isPropagationStopped()){c=e.level,o===!1&&(b=!1);if(a.isImmediatePropagationStopped())break}}return b}}
jQuery16103879226385615766: true
liveFired: HTMLDocument
namespace: ""
namespace_re: /(^|\.)(\.|$)/
result: undefined
target: HTMLFormElement
timeStamp: 1306788242911
type: "ajax:beforeSend"
__proto__: Object
data
中,对吧?不过表单运行得很完美,我可以看到数据已经通过 XMLHttpRequest 发送到了开发工具的网络选项卡中。我不明白。 - David Tuitexhr.data = 'foo'
然后在服务器上记录了请求参数。但它没有被列出来。它似乎也没有影响到其他请求参数。这肯定是我掌握的 jqXHR 对象吗? - David Tuite