• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

xzn_html_tree(1.0) 可折叠大纲

发布: 2007-7-01 15:06 | 作者: admin | 来源: | 查看: 12次 | 进入软件测试论坛讨论

领测软件测试网 <?
/** 可折叠大纲
* 类名 Tree
* 存放位置 xzn/html/tree.php
*/

/** 节点类
* 用于在树中保存相关参数
*
* @param $id    节点号
* @param $text  节点标题
* @param $value 节点参数,一般为url
* @param $image 节点图片
*/
class TreeNode {
  var $id;
  var $text;
  var $value;
  var $image;
  function TreeNode($id,$text,$value,$image) {
    $this->id = $id;
    $this->text = $text;
    $this->value = $value;
    $this->image = $image;
  }
}

/** 树类
* 用于保存和输出可折叠大纲
* 可折叠大纲使用FrontPage 2000的JavaScript脚本
*
* 方法
* set()
* 设置节点,节点编号采用1.2.3.4或1-2-3-4的形式。
* 无层次限制。输入次序不限。
* @param $id    节点号
* @param $text  节点标题
* @param $value 节点参数,一般为url
* @param $image 节点图片
*
* display()
* 向页面输出可折叠大纲
*
* 属性
* @public $node 数组,用于保存节点
* @public $jspath 脚本outline.js存放位置
*/
class Tree {
  var $node;
  var $jspath;
  function set($id,$text,$value="",$image="plus.gif") {
    $d = split("[.-]",$id);
    $e = "";
    for($i=0;$i<count($d);$i++)
      $e .= "[".$d][$i]."]";
    $n = new TreeNode($id,$text,$value,$image);
    eval("\$p=&\$this->node$e;");
    $p[node] = $n;
  }
  function display() {
    echo @#<script language="JavaScript" fptype="dynamicoutline">@#."\n";
    echo @#<!--@#."\n";
    echo @#function dynOutline() {}@#."\n";
    echo @#//-->@#."\n";
    echo @#</script>@#."\n";
    echo @#<script language="JavaScript1.2" fptype="dynamicoutline" src="@#.$jspath.@#outline.js">@#."\n";
    echo @#</script>@#."\n";
    echo @#<script language="JavaScript1.2" fptype="dynamicoutline" for="document" event="onreadystatechange()">@#."\n";
    echo @#<!--@#."\n";
    echo @#initOutline()@#."\n";
    echo @#//-->@#."\n";
    echo @#</script>@#."\n";
    echo @#<table dynamicoutline initcollapsed border="0" cellpadding="0" cellspacing="0"  onclick="dynOutline()">@#."\n";
    ksort($this->node);
    reset($this->node);
    while(list($key,$value) = each($this->node)) {
      $this->next($value,0);
    }
    echo "</table>\n";
  }
  function next($node,$level) {
    if(! is_array($node))
      return;
    if(isset($node[node])) {
//      echo $level.",".$node[node]->id.",".$node[node]->text.",".$node[node]->value.",".$node[node]->image."\n";
      echo @#<tr>@#."\n";
      echo @#<td valign="baseline" width="42"><img src="@#.$node[node]->image.@#"></td>@#."\n";
      echo @#<td valign="top" width="100%">@#;
      if(empty($node[node]->value))
        echo $node[node]->text."\n";
      else
        echo @#<a href="@#.$node[node]->value.@#">@#.$node[node]->text."</a>\n";
      echo @#<table border="0" cellpadding="0" cellspacing="0" width="100%">@#."\n";
    }
    if(count($node) == 1) {
      echo "</td></tr>\n</table>\n";
      return;
    }
    ksort($node);
    reset($node);
    while(list($key,$value) = each($node)) {
      $this->next($value,$level+1);
    }
    echo "</td></tr>\n</table>\n";
  }
}
?>

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网