|
【思路】日历右侧活动列表实现持续时间大于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{ //没占 } }
|
一派護法 十九級 |
接下来是//没占
|