作者共發了15篇帖子。 內容轉換:不轉換▼
 
點擊 回復
338 14
【思路】日历右侧活动列表实现持续时间大于1天的活动块状显示
一派護法 十九級
1樓 發表于:2010-11-10 21:37
一派護法 十九級
2樓 發表于:2010-11-10 21:39

ot.showing=Array();

先建立数组。假设当前遍历到2010年11月10日,对应的表格号(var:itemid)是17。该日期下有一个长3天的活动,也就是持续到12日,那么当前遍历到10日是该活动就没有结束,那么就不显示右圆角。

一派護法 十九級
3樓 發表于:2010-11-10 21:46

此时把活动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]; //表格中的显示顺序

}

?>

一派護法 十九級
4樓 發表于:2010-11-10 21:46
思路又陷入混乱了……整理一下!
一派護法 十九級
5樓 發表于:2010-11-10 21:55

简单写一下:当变量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号就不能显示到……太复杂了,程序中根本无法实现,算了,改用换数组的方法。

一派護法 十九級
6樓 發表于:2010-11-10 22:04

换数组的方法具体是:

ajax返回的xml中的根节点下有很多日期节点,各日期节点下有很多活动节点。先把这些活动节点遍历进入数组,等待排序:

var dn=Array(); //活动节点

dn[i]=Array(); //dn[i]中i为表格号,值为各活动

假设dn[表格号]的数据格式是:Array("活动数据组","活动数据组",...))

若dn[17]==Array(Array("标题","内容"),Array("22","33"));

主动把数组位置调换一下,再遍历数组就可以了。

一派護法 十九級
7樓 發表于:2010-11-10 22:38

回复:6楼

我改在用php-ajax服务器端排序了

一派護法 十九級
8樓 發表于:2010-11-11 13:24
//排序
   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:昨天这个活动的显示序号
    
    //对齐
   }
一派護法 十九級
9樓 發表于:2010-11-11 13:48
//排序
   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{
     # 没占
    }
   }
一派護法 十九級
10樓 發表于:2010-11-11 13:48
算了,没时间了
一派護法 十九級
11樓 發表于:2010-11-11 13:50
时间真是太少了!
一派護法 十九級
12樓 發表于:2010-11-11 22:12
第一步成功了!
一派護法 十九級
13樓 發表于:2010-11-11 22:12
高兴ing!
一派護法 十九級
14樓 發表于:2010-11-11 22:13
//排序
   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{
     //没占
    }
   }
一派護法 十九級
15樓 發表于:2010-11-11 22:13
接下来是//没占

回復帖子

內容:
抱歉,本吧禁止發帖
抱歉,本吧禁止發帖
用戶名: 您目前是匿名發表
(快捷鍵:Ctrl+Enter)
 

本帖信息

點擊數:338 回複數:14
評論數: ?
作者:巨大八爪鱼
最後回復:巨大八爪鱼
最後回復時間:2010-11-11 22:13
 
©2010-2024 Arslanbar Ver2.0
除非另有聲明,本站採用創用CC姓名標示-相同方式分享 3.0 Unported許可協議進行許可。