欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

asp.net GridView 中增加記錄的方法

 更新時(shí)間:2009年03月23日 03:51:01   作者:  
在 ASP.NET 2.0 中,GridView 支持修改/刪除記錄,但卻不支持新增記錄的功能(個(gè)人感覺(jué)是 GridVew 的一大缺憾,估計(jì)在下一版本中會(huì)加入此功能)
大多數(shù)人建議用 FormView 來(lái)完成增加記錄的功能,但是 FormView 和 GridView 不是同一個(gè)表格,所以無(wú)法在同一個(gè)頁(yè)面的同一個(gè)表格中顯示。如果故意將 FormView 或自己的一堆于用新增功能的控件使用普通的表格組裝起來(lái),那么會(huì)碰到一個(gè)很麻煩的問(wèn)題,即兩個(gè)表格的列寬如何協(xié)調(diào)一致,大多數(shù)情況下,大家在做表格的時(shí)候,表格中各列的寬度都是自動(dòng)調(diào)整的,所以強(qiáng)行指定寬度在很多情況下并不適用。
通過(guò)實(shí)踐,想出了一種辦法,主要步驟如下所示:
1) 在 GridView 的 EmptyDataView 中,放置一個(gè)普通的Html Table,以便在GridView綁定的數(shù)據(jù)源中無(wú)數(shù)據(jù)時(shí)依舊顯示表頭(如果數(shù)據(jù)源為返回的數(shù)據(jù)行數(shù)為0,GridView默認(rèn)是不顯示表頭的),假設(shè) ID 為 tbHeader,它的作用是下面用于新增功能的 tbForm 的各列控件提供說(shuō)明(充當(dāng)表頭);
2)在 GridView 下面,放置一個(gè)普通的 HTML 表格,其列數(shù)和 GridView 中定義的列數(shù)保持一致,但行數(shù)只有一行,然后在此表格的各列中放入用于新增功能的各個(gè)控件(如 TextBox等),假設(shè)此表格的 ID 為 tbForm
3)在頁(yè)面中加入一段客戶(hù)端腳本,以便使頁(yè)面展示到客戶(hù)端時(shí),利用 Javascript 將兩個(gè)表格強(qiáng)行合并到一起,這樣就可以將只有一行的 tbForm 合并到 GridView中,因此 GridView 的最下面多出一行,其中有 tbForm 表格中定義的輸入控件和“添加”鏈接(按鈕),主要代碼(JavaScript)如下:
function MergeTable(source,dest)
{
var row;
var cell;
var sourceTb = document.all(source);
var destTb = document.all(dest);
for (var i=0; i<sourceTb.rows.length; i++)
{
row = document.createElement("TR");
for (var j=0; j<sourceTb.rows(i).cells.length; j++)
{
cell = document.createElement("TD");
row.appendChild(cell);
//復(fù)制對(duì)象
for(k=0;k<sourceTb.rows(i).cells(j).all.length;k++)
cell.appendChild(sourceTb.rows(i).cells(j).all.item(k));
}
destTb.tBodies(0).appendChild(row);
}
for (var i=sourceTb.rows.length-1; i>=0; i--)
{
sourceTb.deleteRow(i)
}
}
function ChangeTableLayout()
{
if(document.all('tbHeader') == null)
MergeTable('tbForm','');
else
MergeTable('tbForm','tbHeader');
}
ChangeTableLayout();
如果 GridView 綁定時(shí)沒(méi)有數(shù)據(jù),將不顯示其中定義的各列,而只顯示 EmptyDataView 中的 tbHeader,這時(shí)要合并 tbHeader 和 tbForm。如果 GridView 綁定時(shí)包含數(shù)據(jù),則不會(huì)顯示 EmptyDataView(當(dāng)然也不會(huì)顯示其中的 tbHeader),但這時(shí)會(huì)顯示 GridView 中定義的各個(gè)列,因此只需將 GridView 本身和 tbForm 合并即可。 GridView 的客戶(hù)端ID可以用GridView.ClientID來(lái)獲取。
在服務(wù)器端很容易知道 GridView 綁定后是否包含數(shù)據(jù),但對(duì)于客戶(hù)端來(lái)說(shuō),不容易檢查,一個(gè)簡(jiǎn)單的作法就是檢查頁(yè)面中有沒(méi)有 tbHeader 對(duì)象(如果有,則說(shuō)明表格沒(méi)有數(shù)據(jù),如果無(wú)此對(duì)象,表示 GridView 中包含數(shù)據(jù)... 好啰嗦)
4)如果是 AJAX 環(huán)境,上述腳本有可能不被執(zhí)行,可以調(diào)用 Sys.Application.load.add ( JavaScriptFunction) 來(lái)強(qiáng)制執(zhí)行腳本,來(lái)合并表格,主要代碼如下(C#):
ScriptManager myScriptManager = ScriptManager.GetCurrent(Page);
if (myScriptManager.IsInPartialRenderingMode)
{
Page.ClientScript.RegisterStartupScript(this.GetType(), "ShowFullTable1", "ChangeTableLayout();\n", true);
}
else
{
Page.ClientScript.RegisterStartupScript(this.GetType(), "ShowFullTable2", "Sys.Application.load.add (ChangeTableLayout);\n", true);
}
注:上述代碼中的 ChangeTableLayout 為客戶(hù)端腳本函數(shù)的名稱(chēng),其中調(diào)用第3步驟中的代碼,上述代碼在 Atlas 中通過(guò),在 ASP.NET AJAX Beta 上尚末測(cè)試。
另:為了更能說(shuō)明上文代碼的效果,我抓了一個(gè)截圖,圖中包括表頭在內(nèi)的前三行就是 GridView,最下面一行其實(shí)來(lái)自于另一個(gè)表格,在客戶(hù)端強(qiáng)制合并后,顯示效果就是這樣,看起來(lái)象是一個(gè)表格。

相關(guān)文章

  • .Net語(yǔ)言Smobiler開(kāi)發(fā)利用Gridview控件設(shè)計(jì)較復(fù)雜的表單

    .Net語(yǔ)言Smobiler開(kāi)發(fā)利用Gridview控件設(shè)計(jì)較復(fù)雜的表單

    這篇文章主要為大家詳細(xì)介紹了.Net語(yǔ)言Smobiler開(kāi)發(fā)利用Gridview控件設(shè)計(jì)較復(fù)雜的表單,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Bat自動(dòng)解壓縮發(fā)布asp.net程序

    Bat自動(dòng)解壓縮發(fā)布asp.net程序

    這篇文章主要介紹了Bat自動(dòng)解壓縮發(fā)布asp.net程序的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-12-12
  • Asp.net 中使用GridView控件實(shí)現(xiàn)Checkbox單選

    Asp.net 中使用GridView控件實(shí)現(xiàn)Checkbox單選

    在GridView控件中,第0列有放一個(gè)CheckBox控件,現(xiàn)想實(shí)現(xiàn)對(duì)CheckBox進(jìn)行單選,怎么實(shí)現(xiàn)呢?下面小編通過(guò)本文給大家分享Asp.net 中使用GridView控件實(shí)現(xiàn)Checkbox單選功能,一起看看吧
    2017-07-07
  • Asp.Net Mvc2 增刪改查DEMO代碼

    Asp.Net Mvc2 增刪改查DEMO代碼

    接觸mvc也有一段時(shí)間了(2.0),也看到園子里很多人在學(xué)習(xí),自己也在園子里面看過(guò)前輩們寫(xiě)的博客,確實(shí)受益匪淺。本文寫(xiě)的都是基礎(chǔ)中的基礎(chǔ),僅供想學(xué)習(xí)MVC的新手們?nèi)腴T(mén)之作
    2012-10-10
  • asp.net操作javascript:confirm返回值的兩種方式

    asp.net操作javascript:confirm返回值的兩種方式

    asp.net操作javascript:confirm返回值分為兩種,不使用ajax、使用了ajax,不使用ajax,可以用StringBuilder來(lái)完成
    2014-09-09
  • .NET+JS對(duì)用戶(hù)輸入內(nèi)容進(jìn)行字?jǐn)?shù)提示功能的實(shí)例代碼

    .NET+JS對(duì)用戶(hù)輸入內(nèi)容進(jìn)行字?jǐn)?shù)提示功能的實(shí)例代碼

    .NET+JS對(duì)用戶(hù)輸入內(nèi)容進(jìn)行字?jǐn)?shù)提示功能的實(shí)例代碼,需要的朋友可以參考一下
    2013-06-06
  • C#實(shí)現(xiàn)HTTP協(xié)議迷你服務(wù)器(兩種方法)

    C#實(shí)現(xiàn)HTTP協(xié)議迷你服務(wù)器(兩種方法)

    用C#語(yǔ)言實(shí)現(xiàn)HTTP協(xié)議的服務(wù)器類(lèi)本文將以?xún)煞N稍微有差別的方式用C#語(yǔ)言實(shí)現(xiàn);要完成高性能的Web服務(wù)功能,通常都是需要寫(xiě)入到服務(wù),如IIS,Apache Tomcat感興趣的朋友可以了解下,或許對(duì)你學(xué)習(xí)c#有所幫助
    2013-02-02
  • .net core并發(fā)請(qǐng)求發(fā)送HttpWebRequest的坑解決

    .net core并發(fā)請(qǐng)求發(fā)送HttpWebRequest的坑解決

    這篇文章主要給大家介紹了關(guān)于.net core并發(fā)請(qǐng)求發(fā)送HttpWebRequest的坑的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧
    2018-12-12
  • 利用Service Fabric承載eShop On Containers的實(shí)現(xiàn)方法

    利用Service Fabric承載eShop On Containers的實(shí)現(xiàn)方法

    下面小編就為大家分享一篇利用Service Fabric承載eShop On Containers的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • 在A(yíng)SP.Net Core中使用Lamar的全過(guò)程

    在A(yíng)SP.Net Core中使用Lamar的全過(guò)程

    這篇文章主要給大家介紹了關(guān)于在A(yíng)SP.Net Core中使用Lamar的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評(píng)論