当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 用.Net实现基于CSS的AJAX开发(6)

ASP.NET
AspNetPager与Socut.Data使用方法
asp.net UpdaeProgress的简单用法
asp.net ajaxControlToolkit ValidatorCalloutExtender的简单用法
asp.net 简易生成注册码(数字+大小写字母)
asp.net中利用ashx实现图片防盗链代码
ASP.NET程序中常用代码汇总
ASP.NET 2.0/3.5中直接操作Gridview控件插入新记录
ASP.NET Ajax级联DropDownList实现代码
ASP.NET 2.0写无限级下拉菜单
asp.net Web Services上传和下载文件(完整代码)
asp.net DataGrid控件中弹出详细信息窗口
Asp.NET 多层登陆实现代码
利用Asp.Net回调机制实现进度条
ASP.NET Ref和Out关键字区别分析
Javascript调用Webservice的多种方法
.Net下的签名与混淆图文分析
.Net Compact Framework开发小技巧 推荐
.Net连接Oracle数据库的实现代码
js获取.aspx页面里面的服务器控件和.ascx中的服务器控件值
asp.net下 jquery jason 高效传输数据

ASP.NET 中的 用.Net实现基于CSS的AJAX开发(6)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 207 ::
收藏到网摘: n/a

  headingClicked: function(e) ...{
  
   var that = sorting.that;
  
   // 被点击的目标链接
   var linkEl = getEventTarget(e);
  
   // 直接获取td, tr, thead 和 table
   var td = linkEl.parentNode;
   var tr = td.parentNode;
   var thead = tr.parentNode;
   var table = thead.parentNode;
  
   // 获得目标链接的columnId属性
   var column = linkEl.getAttribute('columnId') || td.cellIndex;
   // 找出当前列的排序方向
   var arrows = css.getElementsByClass(td, 'tableSortArrow', 'span');
   var previousSortOrder = '';
   if (arrows.length > 0) ...{
   previousSortOrder = arrows[0].getAttribute('sortOrder');
   }
  
  
  
   that.lastSortedTable = table.id;
  
   // 将哪一列被排序回馈给用户
  
   // 首先把所有的排序方向复位
   var arrows = css.getElementsByClass(tr, 'tableSortArrow', 'span');
   for (var j = 0; j < arrows.length; j++) ...{
   var arrowParent = arrows[j].parentNode;
   arrowParent.removeChild(arrows[j]);
  
  
   if (arrowParent != td) ...{
   spanEl = createElement('span');
   spanEl.className = 'tableSortArrow';
   // 加入两个空格
   // spanEl.appendChild(document.createTextNode(' '));
   arrowParent.appendChild(spanEl);
   }
  
  
   }
  
   // 现在,回馈给用户
   var spanEl = createElement('span');
   spanEl.className = 'tableSortArrow';
   if (null == previousSortOrder || '' == previousSortOrder || 'DESC' == previousSortOrder) ...{
   spanEl.appendChild(document.createTextNode(' ↑'));
   td.setAttribute('sortOrder', 'ASC');
   spanEl.setAttribute('sortOrder', 'ASC');
   } else ...{
   spanEl.appendChild(document.createTextNode(' ↓'));
   td.setAttribute('sortOrder', 'DESC');
   spanEl.setAttribute('sortOrder', 'DESC');
   }
   td.appendChild(spanEl);
  
   // 以下为没有doPostBack的版本,已经取消
   /**//*
   if(td.firstChild.getAttribute('columnId')!=null) {
   window.location = "?sortdirect="+td.getAttribute('sortOrder')+"&colid="+td.firstChild.getAttribute('columnId');
   }
   else {
   window.location = "?sortdirect="+td.getAttribute('sortOrder')+"&colid="+td.getAttribute('columnId');
   }
   */
  
   // 使用__doPostBack进入后台处理
   __doPostBack('Pars',"sortdirect="+td.getAttribute('sortOrder')+"&colid="+td.firstChild.getAttribute('columnId'));
   return false;
   },
   /**//**
   * 隔行换色
   **/
   doStripe : function(rowItem) ...{
   if (!this.isOdd) ...{
   css.addClassToElement(rowItem, 'odd');
   } else ...{
   css.removeClassFromElement(rowItem, 'odd');
   }
   this.isOdd = !this.isOdd;
   }
  }
  
  function sortInit() ...{
   sorting.init();
  }
  
  addEvent(window, 'load', sortInit)
  
  后台:
  
  
  
  public DataView SortBuilder(object dataobj,DataView dv)
   ...{
   string req = Request.Form["__EVENTARGUMENT"];
   string p_sort = null;
   string p_colid = null;
   if(req!=null)
   ...{
   string[] args = req.Split('&');
   foreach (string arg in args)
   ...{
   string[] hash = arg.Split('=');
   if(hash[0].Equals("sortdirect"))
   ...{
   p_sort = hash[1];
   }
   else if(hash[0].Equals("colid"))
   ...{
   p_colid = hash[1];
   }
   }
   if(p_sort!=null && p_colid!=null && !p_colid.Equals("null"))
   ...{
   SortDirect = p_sort;
   int iColid = Int32.Parse(p_colid);
   if(dataobj is DataGrid)
   ...{
   foreach (DataGridColumn dc in ((DataGrid)dataobj).Columns)
   ...{
   if(((Style)(Style)dc.ItemStyle).CssClass.IndexOf("sortOrder")!=-1)
   ...{
   ((Style)(Style)dc.ItemStyle).CssClass = "";
   }
   }
   ((Style)(((DataGrid)dataobj).Columns[iColid].ItemStyle)).CssClass += " sortOrder" + SortDirect;
   DataGrid grid = (DataGrid)dataobj;
   DataGridColumn dgc = grid.Columns[iColid];
   BoundColumn bc = (BoundColumn)dgc;
   string df = bc.DataField;
   dv.Sort = df + " " + SortDirect;
   }
   if(dataobj is DataList)
   ...{
   DataList dl = (DataList)dataobj;
   ((Style)dl.ItemStyle).CssClass += " sortOrder" + SortDirect;
   dv.Sort = dl.DataKeyField + " " + SortDirect;
   }
   // 自定义控件,,,可以自己实现一个
   if(dataobj is table)
   ...{
   table tbl = (table)dataobj;
   tbl.DataSource = ViewLogic.Data.DataSourceFactory.Create(dv.Table);
   IList list = (tbl).ColumnList;
   tbl.ColName = list[iColid].ToString();
   tbl.SortDriect = SortDirect;
   dv.Sort = list[iColid] + " " + SortDirect;
   }
   }
   }
  
   return dv;
   }
  
   样式绑定的用法如下
  
  例如,排序样式绑定的用法:
  
   前台: 引用JS,并绑定样式 sort
   后台:
   DataSet ds = 获取数据源ds
   DataView dv = ds.Tables[0].DefaultView;
   dv= SortBuilder(控件,dv) ;
   控件.DataSource = newdv; '