|  | 【思路】日历右侧活动列表实现持续时间大于1天的活动块状显示 | 
                
          |   一派護法 十九級 |  | 
                
          |   一派護法 十九級 | 
              ot.showing=Array(); 先建立数组。假设当前遍历到2010年11月10日,对应的表格号(var:itemid)是17。该日期下有一个长3天的活动,也就是持续到12日,那么当前遍历到10日是该活动就没有结束,那么就不显示右圆角。 | 
                
          |   一派護法 十九級 | 
              此时把活动id和该活动在表格中的显示顺序记录入数组ot.showing。 循环段结束,接下来遍历11日。11日中继承活动10日的那个长3天的活动(xml中已返回),此时遍历一下数组: <?js for(i=0;i<ot.showing.length;i++){   dd=ot.showing[i][0]; //活动id   ddd=ot.showing[i][1]; //表格中的显示顺序 } ?> | 
                
          |   一派護法 十九級 | 
              思路又陷入混乱了……整理一下!   | 
                
          |   一派護法 十九級 | 
              简单写一下:当变量j在ot.showing中存在记录时,用空li标签霸占当前的位置,然后再输出当前活动的li标签,假设那个长3日的活动(以后叫x活动)在10日表格中的显示序号为1,那么在11号表格中: 若11号除了x活动外一个活动都没有,那么var:activesnum就等于1,遍历过程如下: for (j=0;j<activesnum;j++,amn++){ 第一次遍历,var:j等于0,此时刚好指向x活动。由于x活动在10号中的显示序号为1,当前序号(var:j)是0,那么10号就不能显示到……太复杂了,程序中根本无法实现,算了,改用换数组的方法。 | 
                
          |   一派護法 十九級 | 
              换数组的方法具体是: ajax返回的xml中的根节点下有很多日期节点,各日期节点下有很多活动节点。先把这些活动节点遍历进入数组,等待排序: var dn=Array(); //活动节点 dn[i]=Array(); //dn[i]中i为表格号,值为各活动 假设dn[表格号]的数据格式是:Array("活动数据组","活动数据组",...)) 若dn[17]==Array(Array("标题","内容"),Array("22","33")); 主动把数组位置调换一下,再遍历数组就可以了。 | 
                
          |   一派護法 十九級 | 
              回复:6楼 我改在用php-ajax服务器端排序了 | 
                
          |   一派護法 十九級 | 
              //排序foreach ($stfed as $i=>$v){
 //$stfed:昨天的全部活动,$stf:今天的全部活动
 //$i:活动编号,$v:活动显示序号
 if (!is_numeric($v)) continue; //若活动显示序号不是数字
 //若昨天的活动编号今天有,则对齐
 //$i就是昨天的活动编号,首先判断今天有没有这个活动,没有的话就continue
 $Is=arraygetid($stf,$i); //键名
 if ($Is<0) continue; //若今天没有这个活动
 $IS=$str[$Is]; //今天这个活动的显示序号
 //$v:昨天这个活动的显示序号
 
 //对齐
 }
 | 
                
          |   一派護法 十九級 | 
              //排序foreach ($stfed as $i=>$v){ //★★这个最好再换一下变量★★
 //$stfed:昨天的全部活动,$stf:今天的全部活动
 //$i:活动编号,$v:活动显示序号
 if (!is_numeric($v)) continue; # 若活动显示序号不是数字
 //若昨天的活动编号今天有,则对齐
 # $i就是昨天的活动编号,首先判断今天有没有这个活动,没有的话就continue
 $Is=arraygetid($stf,$i); # 键名 //★★可能是这个出错了★★
 if ($Is<0) continue; # 若今天没有这个活动
 $IS=intval($str[$Is]); # 今天这个活动的显示序号
 //$v:昨天这个活动的显示序号
 
 
 //对齐
 # 检测今天活动的正确位置是否被其他活动占了
 if (isset($std[$v])){
 # 占了就交换位置
 $a=$std[$IS];
 $b=$std[$v];
 $std[$v]=$a;
 $std[$IS]=$b;
 //$debug.=$IS."||||".$v."||||".$dstr;
 //$debug.=sExplode("|",$stfed); //★有误★
 }else{
 # 没占
 }
 }
 | 
                
          |   一派護法 十九級 | 
              算了,没时间了             | 
                
          |   一派護法 十九級 | 
              时间真是太少了!   | 
                
          |   一派護法 十九級 | 
              第一步成功了!   | 
                
          |   一派護法 十九級 | 
              高兴ing!             | 
                
          |   一派護法 十九級 | 
              //排序foreach ($stfed as $i=>$v){
 /*
 $stfed:昨天的全部活动,$stf:今天的全部活动
 $i:昨天的活动显示序号,$v:昨天的活动编号
 若昨天的活动编号今天有,则对齐
 $i就是昨天的活动编号,首先判断今天有没有这个活动,没有的话就continue
 */
 $Is=arraygetid($stf,$v); //获得今天显示该活动的序号(错误的)
 if ($Is==-1){
 //$v:昨天这个活动的显示序号
 continue; # 若今天没有这个活动
 }
 
 //对齐
 # 检测今天活动的正确位置是否被其他活动占了
 if (isset($std[$i])){
 //占了就交换位置
 $a=$std[$Is]; # 今天活动的错误位置的活动数据
 $b=$std[$i]; # 今天活动的正确位置的活动数据
 $std[$i]=$a;
 $std[$Is]=$b;
 # 纠正$stf数组(防止第三日的活动错位),使各日的活动与第一天平行
 $a=$stf[$Is];
 $b=$stf[$i];
 $stf[$i]=$a;
 $stf[$Is]=$b;
 }else{
 //没占
 }
 }
 | 
                
          |   一派護法 十九級 | 
              接下来是//没占
 |