自己试着写了个无限级分类的,结果有些问题,想了很长时间了,感觉代码没问题呀,可就是结果不正确。现在整个人都懵了....
网上的栗子看了些,貌似写法跟我的不一样。
数组结构如下:
<code>Array ( [0] => Array ( [id] => 1 [name] => 代码 [parent] => 0 ) [1] => Array ( [id] => 3 [name] => 动漫 [parent] => 0 ) [2] => Array ( [id] => 4 [name] => 治愈 [parent] => 3 ) [3] => Array ( [id] => 5 [name] => 励志 [parent] => 3 ) [4] => Array ( [id] => 6 [name] => 机战 [parent] => 3 ) [5] => Array ( [id] => 7 [name] => 百合 [parent] => 3 ) [6] => Array ( [id] => 8 [name] => 资源 [parent] => 0 ) [7] => Array ( [id] => 9 [name] => app [parent] => 8 ) [8] => Array ( [id] => 10 [name] => 软件 [parent] => 8 ) [9] => Array ( [id] => 11 [name] => 黑科技 [parent] => 8 ) )</code>
其中 id
为分类唯一ID, parent
为父类ID
我写的代码 如下:
<code> function all($id=0){ static $_class = null; if(is_null($_class)) $_class = select(); //这个得出来的就是以上的数组结构,然后赋值给了`$_class`变量 $result = array(); foreach($_class as $k => $v){ if($v['parent'] == $id){ unset($_class[$k]); $v = array_merge($v, $this->all($v['id'])); $result['child'][] = $v; } } return $result; } print_r(all(0));</code>
回复内容:
自己试着写了个无限级分类的,结果有些问题,想了很长时间了,感觉代码没问题呀,可就是结果不正确。现在整个人都懵了....
网上的栗子看了些,貌似写法跟我的不一样。
数组结构如下:
<code>Array ( [0] => Array ( [id] => 1 [name] => 代码 [parent] => 0 ) [1] => Array ( [id] => 3 [name] => 动漫 [parent] => 0 ) [2] => Array ( [id] => 4 [name] => 治愈 [parent] => 3 ) [3] => Array ( [id] => 5 [name] => 励志 [parent] => 3 ) [4] => Array ( [id] => 6 [name] => 机战 [parent] => 3 ) [5] => Array ( [id] => 7 [name] => 百合 [parent] => 3 ) [6] => Array ( [id] => 8 [name] => 资源 [parent] => 0 ) [7] => Array ( [id] => 9 [name] => app [parent] => 8 ) [8] => Array ( [id] => 10 [name] => 软件 [parent] => 8 ) [9] => Array ( [id] => 11 [name] => 黑科技 [parent] => 8 ) )</code>
其中 id
为分类唯一ID, parent
为父类ID
我写的代码 如下:
<code> function all($id=0){ static $_class = null; if(is_null($_class)) $_class = select(); //这个得出来的就是以上的数组结构,然后赋值给了`$_class`变量 $result = array(); foreach($_class as $k => $v){ if($v['parent'] == $id){ unset($_class[$k]); $v = array_merge($v, $this->all($v['id'])); $result['child'][] = $v; } } return $result; } print_r(all(0));</code>
unset($_class[$k]);
这一行去掉
鉴于你这个还是用的递归来完成的,我这里提供2个方法,一个是递归的,一个是指针形态的。
第二个可能您暂时无法理解,但是为帮助您学习,以及方便到他人,以下是代码:
使用递归
<code>// 呃,我真不忍心写出这个循环那么多遍的代码,求神解救我。 function _data_to_tree(&$items, $topid = 0, $with_id = TRUE) { $result = []; foreach($items as $v) if ($topid == $v['parent']) { $r = $v + ['children' => _data_to_tree($items, $v['id'], $with_id)]; if ($with_id) $result[$v['id']] = $r; else $result[] = $r; } return $result; } </code>
使用PHP的指针特性
<code>function _data_to_tree($items, $topid = 0, $with_id = TRUE) { if ($with_id) foreach ($items as $item) $items[ $item['parent'] ]['children'][ $item['id'] ] = &$items[ $item['id'] ]; else foreach ($items as $item) $items[ $item['parent'] ]['children'][] = &$items[ $item['id'] ]; return isset($items[ $topid ]['children']) ? $items[ $topid ][ 'children' ] : []; }</code>
使用
传入你的上述数组,比如最顶层的ID为0
<code>$data = [ ['id' => 4, 'parent' => 1 , 'text' => 'Parent1'], ['id' => 1, 'parent' => 0 , 'text' => 'Root'], ['id' => 2, 'parent' => 1 , 'text' => 'Parent2'], ['id' => 3, 'parent' => 2 , 'text' => 'Sub1'], ]; print_r ( _data_to_tree($data, 0) ); </code>
结果
<code>Array ( [1] => Array ( [id] => 1 [parent] => 0 [text] => Root [children] => Array ( [4] => Array ( [id] => 4 [parent] => 1 [text] => Parent1 [children] => Array ( ) ) [2] => Array ( [id] => 2 [parent] => 1 [text] => Parent2 [children] => Array ( [3] => Array ( [id] => 3 [parent] => 2 [text] => Sub1 [children] => Array ( ) ) ) ) ) ) )</code>

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增强codemodocultion,可验证性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

选择DependencyInjection(DI)用于大型应用,ServiceLocator适合小型项目或原型。1)DI通过构造函数注入依赖,提高代码的测试性和模块化。2)ServiceLocator通过中心注册获取服务,方便但可能导致代码耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)启用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替换loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化进行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)

tomakephpapplicationsfaster,关注台词:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

到ImprovephPapplicationspeed,关注台词:1)启用opcodeCachingwithapCutoredUcescriptexecutiontime.2)实现databasequerycachingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandredececonnection.4 limitsclection.4.4

依赖注入(DI)通过显式传递依赖关系,显着提升了PHP代码的可测试性。 1)DI解耦类与具体实现,使测试和维护更灵活。 2)三种类型中,构造函数注入明确表达依赖,保持状态一致。 3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

databasequeryOptimizationinphpinvolVolVOLVESEVERSEVERSTRATEMIESOENHANCEPERANCE.1)SELECTONLYNLYNESSERSAYCOLUMNSTORMONTOUMTOUNSOUDSATATATATATATATATATATRANSFER.3)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Dreamweaver CS6
视觉化网页开发工具

Atom编辑器mac版下载
最流行的的开源编辑器