submit和ajax提交的区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了submit和ajax提交的区别相关的知识,希望对你有一定的参考价值。

参考技术A submit提交和ajax提交的区别

submit会刷新页面,ajax不会刷新页面form表单内有button的type为submit的按钮可以点击按钮提交表单,触发submit事件form表单内即使没有button的type为submit的按钮,也可以在输入框内回车来提交,触发submit事件在submit事件中,阻止默认事件或返回false,可停止提交表单,例如表单校验但是如果你的数据需要处理,就需要在submit中阻止原生提交,自定义用ajax来提交.

Ext.Ajax.request和formPanel.getForm().submit()两种提交方法的异同:

 

Ext.Ajax.request和formPanel.getForm().submit()两种提交方法的异同:

1、 相同点:

a) 都是使用异步提交的方式;

b) 默认都是使用POST方式来提交数据;

 

2、 不同点:

a) Request方法不可以使用waitMsg属性来设置在等待响应过程中显示的信息,而submit方法提交时这个设置是可用的(可以看到效果,而前面说的不可用是指设置了看不到效果);

b) Request方法必须将要提交的参数手动组织好然后作为名为params的参数的值才能提交到服务器,而submit方法会将表单内所有input元素组织好提交;

c)  Request方法提交时,回调函数中会传入两个参数(response,option),前者是请求的响应对象,服务器对于请求的响应信息可以通过它的responseText属性得到(也就是response.reponseText就可以得到服务器返回的字符串),第二个参数是提交的参数对象,一般不需要用到,如果要读取返回的响应信息,要先用Ext.decode方法将其resonseText属性值转换成json对象才可以读取;如服务器端返回的是一个json格式的字符串:{success:true,msg:‘sample‘},则客户端要读取这个信息,可以这样:var returnResult = Ext.decode(response.responseText); alert(returnResult.msg);submit的情况下回调函数参数是(form,action),如果想读取响应信息,只需要访问action对象的result属性就可以了,像上述同样的返回信息,读取的示例:alert(action.result.msg);不过有一点要注意的是,当网络数据传输失败或信息丢失的情况下,action中可能没能取到服务器返回的消息,也就是说,result不一定会存在msg属性,如果不经判断就访问,有可能会引发异常;

d) Request方法提交后,无论返回的json结果中success属性是否为true,回调函数都会到success:function()里面执行,所以在这种情况下,必须在success方法体里再到result.success进行判断以得到真正的执行结果,所以,只有在出现网络错误,连不到服务器或找到响应页面(404)时,failure回调方法才会被执行;而Submit方法在返回的结果中,如果success为true的,就会自动执行success:function,如果是false,则会执行failure:function了,所以没有必要再在里面判断success是true或false,另,跟request时一样,当出现网络错误或其它未知错误时,failure:function也会被执行;

备注:造成这种结果的原因不难理解,因为在上面第三点提到,request请求的情况下返回的结果是以字符串的形式获取的,也就是说ext并未到其进行解析,所以它也识别不了里面返回的结果是成功还是失败,只是把一个字符串带回来了,而submit方法提交时,返回的action.result对象已经将响应信息解析了,它能读取其中的success属性的值,所以能够根据不同的success属性来执行相应的回调方法)

 

以上是关于submit和ajax提交的区别的主要内容,如果未能解决你的问题,请参考以下文章

form表单submit提交内容,跟ajax异步提交form表单的区别,

在jQuery ajax中按钮button和submit的区别分析

一个页面中可不可以同时使用submit提交表单和ajax提交表单

如果存在错误,则防止表单提交 ajax .submit() 和 .change()

Ext.Ajax.request和formPanel.getForm().submit()两种提交方法的异同:

js表单提交和submit提交的区别