ruby-on-rails – 如何在Rails中将数据附加到jquery-ujs发布请求
发布时间:2020-12-16 22:31:49 所属栏目:百科 来源:网络整理
导读:我有一个具有data-remote =“true”属性的Ajax表单,我正在rails中的控制器. 我想做的是在发送到服务器之前使用jquery-ujs event system将数据附加到请求中. 这样的东西 $("#my_form").bind('ajax:beforeSend',function(xhr,settings){ // serialize some obj
我有一个具有data-remote =“true”属性的Ajax表单,我正在rails中的控制器.
我想做的是在发送到服务器之前使用jquery-ujs event system将数据附加到请求中. 这样的东西 $("#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 解决方法
我最后想到了这一个.看来,尽管
docs说,ajax:beforeSend hook实际上有三个参数.根据
this helpful blog post他们是事件,xhr和这个顺序的设置.
我正在寻找的表单数据是在设置参数的data属性中. 所以基本上,我现在可以使用该函数向请求添加数据 $("#my_form").bind('ajax:beforeSend',function(event,xhr,settings){ settings.data += "&serialized=data"; }); 而额外的参数将在服务器上可用. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |