• 您的信息
      • 日期时间
        2025年3月8日 星期六
        【蛇】己卯月丙子日
        乙巳年 二月初九
        妇女节
        您的信息
        您的IP:
        3.145.109.147
        操作系统:
        未知操作系统
        浏览器:
        未知浏览器
        分辨率:
        1280x720
        位置:
        缂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鎮㈤崗灏栨嫽闁诲酣娼ф竟濠偽i鍓х<闁绘劦鍓欓崝銈囩磽瀹ュ拑韬€殿喖顭烽幃銏ゅ礂鐏忔牗瀚介梺璇查叄濞佳勭珶婵犲伣锝夘敊閸撗咃紲闂佺粯鍔﹂崜娆撳礉閵堝棛绡€闁逞屽墯濞煎繘鍩¢崒銈嗙稐闂備礁婀遍崕銈夊蓟閿熺姴纾婚柟鍓х帛閺呮煡骞栫划鍏夊亾閹绘帩妫滅紓鍌氬€烽悞锔芥櫠鎼淬劌鐤炬繝濠傛噺瀹曞弶绻涢幋鐑囦緵闁哥喎鎳忛妵鍕籍閸パ冩優闂佺儵鏅涢柊锝夊蓟濞戙垹唯闁挎棁妫勯崬澶娾攽椤旂》榫氭繛鍜冪秮瀹曠娀寮介鐐插祮闂佺粯娲戠拋鏌ュ磻閹捐骞㈡繛鎴炵懅閸樻悂姊洪崨濠佺繁闁哥姵宀搁幆宀勫箳閹惧彉绨婚梺闈涢獜缁辨洟骞婇崶鈹惧亾濞堝灝娅橀柛锝忕到閻g兘骞掗幋鏂跨墯闂佸憡绮岄崯浼存⒒椤栨稓绡€闁汇垽娼ф禒鈺呮煙濞茶绨界€垫澘锕幊鐐哄Ψ瑜忚ぐ鐐節閻㈤潧孝婵炲眰鍊楁竟鏇㈠锤濡や胶鍘甸梺瑙勵問閸犳牠銆傛總鍛婄厽闁规儳宕崝婊呯磼缂佹ḿ娲存鐐差儔閹瑩宕归銏$彫缂傚倸鍊风拋鏌ュ磻閹炬剚鐔嗛柤鎼佹涧婵牓鏌i幘宕囩闁哄本鐩俊鐑芥晲閸涱収鐎冲┑鐘愁問閸犳牜绮旈悽鎼炩偓鍐Ψ閳哄倸鈧兘鏌℃径瀣仸閻犲洨鍋涜灃闁绘﹢娼ф禒锕€鐣濋敐鍛仴闁糕斁鍋撳銈嗗笂閼冲爼鍩婇弴銏$叆闁哄洦顨嗗▍鍡欑磼閸屾稑绗╂い锕侇潐閹便劍绻濋崒銈囧悑閻庤娲樼敮鎺楀煝鎼淬劌绠涙い鏂挎惈娴犳帒鈹戦悩鍨毄闁稿鐩棟闁哄锛曞ú顏呭亜濡炲瀛╁▓楣冩⒑鐟欏嫬鍔跺┑顔哄€濆鎻掆攽鐎n偆鍘遍柣蹇曞仧閸嬫捇鎯冮幋鐐簻闁哄倹瀵чˉ銏℃叏婵犲懏顏犻柟鐟板婵℃悂濡烽敂鎯х稈闂傚倷鑳堕幊鎾诲吹閺嶎厼绠柨鐕傛嫹 Amazon EC2闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄥジ鏌熼惂鍝ョМ闁哄矉缍侀、姗€鎮欓幖顓燁棧闂備線娼уΛ娆戞暜閹烘缍栨繝闈涱儐閺呮煡鏌涘☉鍗炲妞ゃ儲鑹鹃埞鎴炲箠闁稿﹥顨嗛幈銊╂倻閽樺锛涢梺缁樺姉閸庛倝宕戠€n喗鐓熸俊顖濆吹濠€浠嬫煃瑜滈崗娑氭濮橆剦鍤曢柟缁㈠枛椤懘鏌嶉埡浣告殲闁绘繃娲熷缁樻媴閽樺-鎾绘煥濮橆厹浜滈柨鏃囶嚙閺嬨倗绱掓潏銊︻棃鐎殿喗鎸虫慨鈧柍閿亾闁归绮换娑欐綇閸撗呅氬┑鐐叉嫅缂嶄焦淇婄€涙ḿ绡€闁搞儯鍔庨崢閬嶆⒑鐟欏嫬鍔ゆい鏇ㄥ幘缁鎮欓悜妯煎幍濡炪倖姊婚崑鎾绘倿閹稿簺浜滈柨鏇楀亾缂傚秴锕濠氭偄绾拌鲸鏅┑顔角规禍顒勫礉椤栨鏃堟偐闂堟稐娌€光偓閿濆牊纭舵俊鍙夊姍楠炴帡骞婂畷鍥ф灁闁诡喕鍗抽崹楣冨礂閸涱収妫滈梻鍌欑婢瑰﹪鎮¢崼銉ョ;闁糕剝鐟ф稉宥呂旈敐鍛殲闁绘挻鐟╅幃妤呮偨閻ц缍婂畷婊堝础閻忚缍婇幃鈩冩償閵忊晜锛嗛梻浣告惈閻ジ宕伴幇顑肩細闊洦绋戠粈鍫㈡喐韫囨稑姹查柣妯肩帛閳锋垶绻涢懠棰濆殭妤犵偞顨嗛妵鍕Ω閵夘垵鍚梺璇″櫙缁绘繈銆侀弴銏℃櫇闁逞屽墴閹瑦绻濋崶銊у帾婵犵數鍊埀顒勫磻閹炬枼鏀芥い鏂垮悑閸犳ɑ鎱ㄦ繝鍛仩缂佽鲸甯掕灒閻犲洤寮跺▓顐︽⒒娴e憡鎲稿┑顔炬暬閹囨偐瀹割喖娈ㄦ繝鐢靛У绾板秹寮查幖浣圭厽婵☆垰鐏濋惃鐑樸亜閿斿搫濮傛慨濠冩そ濡啫霉閵娿儳绉虹€规洘娲熼、姘跺焵椤掆偓閻g兘骞嬮敃鈧粻濠氭偣閸ヮ亜绱︾紒鍗炵埣濮婃椽妫冨☉杈€嗛梻鍌氬鐎氼剟鍩㈤幘鏉戭嚤閻庢稒菤閹锋椽姊洪崨濠冨鞍鐟滄澘鍟粋宥呪攽閸モ晝顔曢梺鍛婄懃椤р偓闁兼澘娼¢弻娑㈠煛閸屾粍鍒涘Δ鐘靛仦鐢帟鐏冩繛杈剧到閹碱偊鐛崼銉︹拺閻犲洩灏欑粻鎶芥煕鐎n剙鈻堟い銏′亢椤﹀綊鏌涢埞鎯т壕婵$偑鍊栫敮濠囨倿閿斿墽鐭嗛悗锝庡枟閻撴瑦銇勯弮鈧弸濠氭嚀閸ф鐓涘ù锝嚽归弳锝団偓瑙勬礃鐢帡鍩ユ径濠庢僵妞ゆ巻鍋撶紒鐘卞嵆濮婄粯鎷呯粵瀣缂備胶绮敮鈥崇暦閹达附鍋愭繛鑼帛閺咁亪鎮峰⿰鍐弰妤犵偛鐗撴俊鎼佸煛娴g尨绱查梻浣虹帛閸旀洟顢氶銏犲偍闂傚牊渚楀〒濠氭煏閸繃顥為柣鎾卞劦閺岀喓鍠婇崡鐐板枈闂佺硶鏂侀崑鎾愁渻閵堝棗绗傞柤鍐插缁骞樼紒妯煎幗闂佹寧绻傚ú銈夊储鐎涙﹩娈介柣鎰綑濞搭喗顨ラ悙宸剶鐎殿噮鍣i崺鈧い鎺戝缂嶆牜鈧箍鍎遍幊澶愬绩閼恒儯浜滈柡鍐ㄥ€婚幗鍌涚箾閸喐鈷愬ǎ鍥э躬椤㈡洟鏁愰崱蹇斿婵犵鈧啿绾ч柛鏃€鐟╁顐﹀箻缂佹ɑ娅㈤梺璺ㄥ櫐閹凤拷
        您的天气
          正在获取信息 ...
随笔 - 3461, 文章 - 0, 评论 - 739, 阅读 - 1200万
  管理

DataGrid的几个小技巧

Posted on   lzhdim  阅读(537)  评论(0编辑  收藏  举报
删除时给出提示
  方法一:使用模版列
  
  我们在绑定好数据的DataGrid增加一个模版列,在列中放置一个按钮
  <asp:TemplateColumn>
  <ItemTemplate>
  <asp:Button id="btnDelete" runat="server" Text="删除"></asp:Button>
  </ItemTemplate>
  </asp:TemplateColumn>
  然后我们在DataGrid的ItemDataBound中添加以下代码
  switch(e.Item.ItemType)
  {
  case(ListItemType.Item):
  case(ListItemType.AlternatingItem):
  {
  Button btn=(Button)e.Item.FindControl("btnDelete");
  btn.Attributes.Add("OnClick","return window.confirm('fs')");
  break;
  }
  }
  DataGrid在绑定数据的时候将触发此事件,而且每行触发一次.我们可以通过e.Item获得行,而通过e.Item.ItemType获得行类型.
  
  方法二:使用按钮列
  
  我们在绑定好数据的DataGrid增加一个删除按钮列
  <asp:ButtonColumn Text="删除" CommandName="Delete"></asp:ButtonColumn>
  然后我们在DataGrid的ItemDataBound中添加以下代码
  switch(e.Item.ItemType)
  {
  case(ListItemType.Item):
  case(ListItemType.AlternatingItem):
  {
  LinkButton btn=(LinkButton)e.Item.Cells[4].Controls[0];
  btn.Attributes.Add("OnClick","return window.confirm('fs')");
  break;
  }
  }
  可以看到我们这里获得控件引用的方法有所不同,使用了e.Item.Cells[4].Controls[0],而没有使用e.Item.FindControl("btnDelete"),因为我
  
  
  们现在使用的是按钮列,不能对按钮列的按钮设置ID属性,而FindControl是通过ID来查找控件(当然我们也可以把前面的代码用
  
  
  e.Item.Cells[4].Controls[0]的代码来替换.).
  
  
  
  添加序号列
  绑定好一个DataGrid
  switch(e.Item.ItemType)
  {
  case(ListItemType.Item):
  case(ListItemType.AlternatingItem):
  {
  DataGridItem row=(DataGridItem)e.Item;
  TableCell cell=new TableCell();
  cell.Controls.Add(new LiteralControl((e.Item.ItemIndex+1).ToString()));
  row.Cells.AddAt(0,cell);
  break;
  }
  case(ListItemType.Header):
  {
  DataGridItem row=(DataGridItem)e.Item;
  TableCell cell=new TableCell();
  cell.Controls.Add(new LiteralControl("序号"));
  row.Cells.AddAt(0,cell);
  break;
  }
  }
  这里我们用到了e.Item.ItemIndex,获取来自 DataGrid 控件的 Items 集合的 DataGridItem 对象的索引.
  
  
  产生两行的标题行
  绑定好一个DataGrid,设置允许分页,设置页导航为上下型,一会我们将强制把上面的页导航更换成标题行.这里我想讲一下DataGrid的行构成
  最上面Pager,用来放置分页导航,然后是表头Header,接着是Item和AlternatingItem项目和交替项目(当然还有SelectedItem选中项和EditItem
  
  
  编辑项等),然后是Footer表脚,最下面还有一个Pager.因为Pager行是系统自动产生的,所以在ItemDataBound事件中不能捕获此行,这里我使用了
  
  
  ItemCreated事件,添加代码如下
  switch(e.Item.ItemType)
  {
  case(ListItemType.Pager):
  {
  if(first)
  {
  DataGridItem row=(DataGridItem)e.Item;
  row.Cells.Clear();
  TableCell cell0=new TableCell();
  cell0.Controls.Add(new LiteralControl("ID"));
  TableCell cell1=new TableCell();
  cell1.ColumnSpan=2;
  cell1.Controls.Add(new LiteralControl("FullName"));
  row.Cells.Add(cell0);
  row.Cells.Add(cell1);
  }
  first=!first;
  break;
  }
  }
  这里的First用来判断是上面的Pager还是下面的Pager.
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
2025年3月8日 星期六 【蛇】己卯月丙子日 乙巳年 二月初九 妇女节
您的IP:3.145.109.147,操作系统:未知操作系统,浏览器:未知浏览器
Copyright (C) 2000-2025 Lzhdim Software All Rights Reserved
点击右上角即可分享
微信分享提示