日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ExtJs 备忘录(4)—— Form表单(四) [ 数据提交 ]

發布時間:2025/3/8 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ExtJs 备忘录(4)—— Form表单(四) [ 数据提交 ] 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、截圖和示例共用Ext.FormPanel
    1.1  截圖
      
      由于本文主要關注的是表單提交的幾種方式,所以僅用了一個表單項以便于測試和減少示例代碼。
    1.2  示例共用Ext.FormPanel ????<script?type="text/javascript">
????????Ext.onReady(
function()?{
???????????Ext.QuickTips.init();
???????????Ext.form.Field.prototype.msgTarget?
=?'side';
????????????
????????????
var?form1?=?new?Ext.FormPanel({
????????????????frame:?
true,
????????????????renderTo:?Ext.getBody(),
????????????????title:?
'<center>表單提交</center>',
????????????????style:?
'margin-left:auto;margin-right:auto;width:500px;margin-top:8px;',
????????????????labelAlign:?
'right',
????????????????labelWidth:?
170,
????????????????buttonAlign:
'center',
????????????????items:?[
new?TextField('param2','表單項')]
????????????});
????????});
????
</script>     關于封裝后的表單控件,可以參照系列的前幾篇文章,也可以在后面的源代碼里面找到相關的封裝代碼。
二、普通方式提交
    適合一次操作頁面,即提交后跳轉到另外一個頁面。
    前臺代碼: ????????????????????text:?"普通方式",
????????????????????handler:
function(){
????????????????????????
if(form1.form.isValid()){
????????????????????????????
//只用指定TextField的id或者name屬性,服務器端Form中就能取到表單的數據
????????????????????????????//如果同時指定了id和name,那么name屬性將作為服務器端Form取表單數據的Key
????????????????????????????var?form?=?form1.getForm().getEl().dom;
????????????????????????????form.action?
=?'submit.aspx?method=Submit1&param1=abc';
????????????????????????????
//指定為GET方式時,url中指定的參數將失效,表單項轉換成url中的key=value傳遞給服務端
????????????????????????????//例如這里指定為GET的話,url為:submit.aspx?param2=你輸入的值
????????????????????????????//form.method?=?'GET';//GET、POST
????????????????????????????form.submit();
????????????????????????}
????????????????????}
    代碼說明:這段代碼加在buttons:[{}]里面中。
    后臺代碼: ????///?<summary>
????
///?POST普通提交
????
///?</summary>
????
///?<returns></returns>
????public?void?Submit1()
????{
????????
//數據庫操作
????????string?param1?=?Request.QueryString["param1"];
????????
string?param2?=?Request.Form["param2"];
????????
//Response.Write(string.Format("param1(GET):{0}<br?/>param2(POST):{1}<br?/>",?Request.QueryString["param1"],?Request.Form["param2"]));
????????
//頁面掉轉
????????Response.Redirect("esayadd.aspx");
????}
?    普通提交我也翻閱了不少文章,在3.0版本中可以如上實現比較簡單,或者直接設置FormPanel的standardSubmit:true屬性,則下面默認Ajax提交方式也將變成普通的表單提交。注意這里并不需要設置 onSubmit: Ext.emptyFn等,表單項的id和name指定也在注釋里面有說明了。
三、Ajax方式提交
    3.1 ?默認方式
      客戶端代碼: ????????????????????text:?"默認方式",
????????????????????handler:
function(){?
????????????????????????form1.getForm().submit({
????????????????????????????url:
'submit.aspx?method=Submit2&param1=abc',
????????????????????????????
//method:'POST',
????????????????????????????//waitTitle?:?"提示",
????????????????????????????//waitMsg:?'Submitting?your?data',
????????????????????????????success:?function(form,?action){
????????????????????????????????alert(action.response.responseText);
????????????????????????????},
????????????????????????????failure:?
function(form,?action){
????????????????????????????????alert(action.result.errormsg);
????????????????????????????}
????????????????????????});
????????????????????}
      服務器端代碼: ????///?<summary>
????
///?默認方式
????
///?</summary>
????public?void?Submit2()
????{
????????
string?param1?=?Request.QueryString["param1"];
????????
string?param2?=?Request.Form["param2"];
????????
//必須返回JOSIN形式數據
????????Response.Write("{success:true}");
????????Response.End();
????}
      代碼說明:
        a).  服務器端必須返回JSON格式,success返回true則執行success:?function(form,?action)里面的代碼,返回false則執行failure:?function(form,?action)中的代碼。
        b).  服務器端必須Response.End();
        寫測試代碼的時候就是因為沒有按這個格式返回,一直以為客戶端代碼是否有問題,耽誤了挺多時間。
    3.2  通過Ext.data.Connection提交數據
      客戶端代碼: ????????????????????text:?"Connect方式",
????????????????????handler:
function(){?
????????????????????????
//注意
????????????????????????var?conn?=?new?Ext.data.Connection();
????????????????????????conn.request({
????????????????????????????url:?
'submit.aspx?method=Submit4',
????????????????????????????
//此處與params對應,如果為POST,則服務器端從Request.Form中可以取得到數據,反之從QueryString中取數據
????????????????????????????method:?'POST',//GET
????????????????????????????params:form1.form.getValues(),
????????????????????????????success:?
function(response,?opts)?{
?????????????????????????????????MsgInfo(response.responseText);
????????????????????????????}
????????????????????????});
????????????????????}
      服務器端代碼: ????///?<summary>
????///?Connect方式
????///?</summary>
????public?void?Submit3()
????{
????????string?param1?
=?Request.QueryString["param1"];
????????string?param2?
=?Request.Form["param2"];
????????Response.Write(
"ok");
????????Response.End();
????}
      代碼說明:
        這里就沒有限制返回的數據格式了,但仍需要設置Response.End(),所以默認在PageBase里面設置了此代碼。
    3.3  通過Ext.Ajax提交數據
      客戶端代碼: ????????????????????//Ext.Ajax是繼承Ext.data.Connection而來
????????????????????text:?"Ajax方式",
????????????????????handler:
function(){?
????????????????????????Ext.Ajax.request({
????url:?
'submit.aspx?method=Submit3',
????method:?
'POST',
????
//jsonData://指定需要發送給服務器端的JSON數據。如果指定了該屬性則其它的地方設置的要發送的參數值將無效。
        ????//xmlData://指定用于發送給服務器的xml文檔,如果指定了該屬性則其它地方設置的參數將無效。
        ????params:form1.form.getValues(),//取得key/value對象數組
        ????//指定Ajax請求的回調函數,該函數不管是調用成功或失敗,都會執行。
        ????callback:?function?(options,?success,?response)?{
??????????
if(success){
????????MsgInfo(response.responseText);
????}
????}
????????});
????????????????????}
      服務器端代碼: ????///?<summary>
????
///?Ajax方式
????
///?</summary>
????public?void?Submit4()
????{
????????
string?param1?=?Request.QueryString["param1"];
????????
string?param2?=?Request.Form["param2"];
????????Response.Write(
"yes");
????????Response.End();
????}
    Ajax方式提交總結:
      a).  服務器端處理返回數據后都需要Response.End();
      b).  很明顯,Ajax的特點之一就是不刷新頁面,提高用戶體驗。
      c).  回調分為callback和success+failure兩種方式,后面是將前面的拆成2個函數來處理。
四、下載

    ExtJS2009-10-2.rar

本文轉自博客園農民伯伯的博客,原文鏈接:ExtJs 備忘錄(4)—— Form表單(四) [ 數據提交 ],如需轉載請自行聯系原博主。

總結

以上是生活随笔為你收集整理的ExtJs 备忘录(4)—— Form表单(四) [ 数据提交 ]的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 黄色大片在线看 | 中文字幕一区二区三区四区欧美 | 日本中文字幕在线观看视频 | 国产a网站 | 在线视频二区 | 乱妇乱女熟妇熟女网站 | 天天色天天干天天色 | 亚洲伦理中文字幕 | 日韩欧美在线观看一区二区三区 | 国产精品国产三级国产aⅴ原创 | 精品人妻久久久久一区二区三区 | 亚洲av无码乱码国产精品fc2 | 爱爱福利社 | 肉丝超薄少妇一区二区三区 | 日本妇女毛茸茸 | 欧美在线天堂 | 午夜tv影院| 日本黄大片在线观看 | 九九视频在线播放 | 亚洲日日日 | 中文字幕在线观看你懂的 | www狠狠| 欧美人与物videos另类 | 一级黄色小视频 | 午夜精品久久久久久久爽 | 色多多在线视频 | 淫片一级国产 | 久久午夜网 | 日韩成人精品在线观看 | 精品一区二区三区四区五区 | 国产精品夫妻 | 日韩不卡视频在线 | jizzjizz国产 | 亚洲欧洲国产视频 | 欧美极品在线观看 | 日韩免费福利视频 | 91激情在线观看 | 成人av影视在线 | 日韩极品在线观看 | 综合激情久久 | 美国三级a三级18 | 欧美片在线观看 | 国产毛片儿 | 高潮毛片无遮挡免费看 | 91天堂在线观看 | 亚洲少妇色| 国产福利视频在线观看 | 日本老妇高潮乱hd | 国产一区二区在线不卡 | 午夜成人鲁丝片午夜精品 | 色婷婷社区| 日批网站在线观看 | 在线免费观看污片 | 大尺度av | 人禽l交视频在线播放 视频 | 日韩欧美一区二区三区四区 | 国语对白一区二区三区 | 小宵虎南在线观看 | 激情综合五月婷婷 | 国产精品久久色 | 91高跟黑色丝袜呻吟在线观看 | 九色精品在线 | 成年人视频网站 | 国产在线视频一区二区 | 久久久人| 日韩免费福利视频 | 中文日韩 | 欧美视频在线免费 | 国产精品视频免费观看 | 亚洲色图综合在线 | 国产精品一区二区久久毛片 | 亚洲综合小说 | 国产二区一区 | 中文字幕系列 | 日韩精品在线免费观看视频 | 天天成人 | 中文字幕在线看高清电影 | 亚洲天堂精品在线观看 | 国产女同91疯狂高潮互磨 | 欧美 变态 另类 人妖 | 国产精品理论片在线观看 | 色欲无码人妻久久精品 | 免费成人蒂法网站 | 欧美aⅴ| 色婷婷在线观看视频 | 色在线视频观看 | aaa黄色大片 | 污黄视频在线观看 | 超清纯大学生白嫩啪啪 | 夜色伊人 | 国产精选第一页 | 女人扒开腿免费视频app | 国产麻豆剧传媒精品国产 | 欧美一级录像 | 欧美人与动物xxxxx | 国产精品亚洲第一 | 成人在线91 | 欧美中文字幕一区二区三区 | v99av|