Rumah pembangunan bahagian belakang tutorial php php无限级分类_PHP教程

php无限级分类_PHP教程

Jul 14, 2016 am 10:08 AM
http php Pengelasan bekalan kaedah tidak terhad daripada

CI的seven给我提供了一个方法,如下:

[php]  
  
/** 
 * 此方法由@Tonton 提供 
 * http://my.oschina.net/u/918697 
 * @date 2012-12-12  
 */  
function genTree5($items) {   
    foreach ($items as $item)   
        $items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];   
    return isset($items[0]['son']) ? $items[0]['son'] : array();   
}   www.2cto.com
  
/** 
 * 将数据格式化成树形结构 
 * @author Xuefen.Tong 
 * @param array $items 
 * @return array  
 */  
function genTree9($items) {  
    $tree = array(); //格式化好的树  
    foreach ($items as $item)  
        if (isset($items[$item['pid']]))  
            $items[$item['pid']]['son'][] = &$items[$item['id']];  
        else  
            $tree[] = &$items[$item['id']];  
    return $tree;  
}  
  
$items = array(  
    1 => array('id' => 1, 'pid' => 0, 'name' => '江西省'),  
    2 => array('id' => 2, 'pid' => 0, 'name' => '黑龙江省'),  
    3 => array('id' => 3, 'pid' => 1, 'name' => '南昌市'),  
    4 => array('id' => 4, 'pid' => 2, 'name' => '哈尔滨市'),  
    5 => array('id' => 5, 'pid' => 2, 'name' => '鸡西市'),  
    6 => array('id' => 6, 'pid' => 4, 'name' => '香坊区'),  
    7 => array('id' => 7, 'pid' => 4, 'name' => '南岗区'),  
    8 => array('id' => 8, 'pid' => 6, 'name' => '和兴路'),  
    9 => array('id' => 9, 'pid' => 7, 'name' => '西大直街'),  
    10 => array('id' => 10, 'pid' => 8, 'name' => '东北林业大学'),  
    11 => array('id' => 11, 'pid' => 9, 'name' => '哈尔滨工业大学'),  
    12 => array('id' => 12, 'pid' => 8, 'name' => '哈尔滨师范大学'),  
    13 => array('id' => 13, 'pid' => 1, 'name' => '赣州市'),  
    14 => array('id' => 14, 'pid' => 13, 'name' => '赣县'),  
    15 => array('id' => 15, 'pid' => 13, 'name' => '于都县'),  
    16 => array('id' => 16, 'pid' => 14, 'name' => '茅店镇'),  
    17 => array('id' => 17, 'pid' => 14, 'name' => '大田乡'),  
    18 => array('id' => 18, 'pid' => 16, 'name' => '义源村'),  
    19 => array('id' => 19, 'pid' => 16, 'name' => '上坝村'),  
);  
echo "
";  
Salin selepas log masuk
print_r(genTree5($items));  
print_r(genTree9($items));  
  
//后者输出格式,前者类似,只是数组键值不一样,不过不影响数据结构  
/*  
Array  
(  
[0] => Array  
    (  
        [id] => 1  
        [pid] => 0  
        [name] => 江西省  
        [son] => Array  
            (  
                [0] => Array  
                    (  
                        [id] => 3  
                        [pid] => 1  
                        [name] => 南昌市  
                    )  
  
                [1] => Array  
                    (  
                        [id] => 13  
                        [pid] => 1  
                        [name] => 赣州市  
                        [son] => Array  
                            (  
                                [0] => Array  
                                    (  
                                        [id] => 14  
                                        [pid] => 13  
                                        [name] => 赣县  
                                        [son] => Array  
                                            (  
                                            [0] => Array  
                                                (  
                                                    [id] => 16  
                                                    [pid] => 14  
                                                    [name] => 茅店镇  
                                                    [son] => Array  
                                                        (  
                                                        [0] => Array  
                                                            (  
                                                            [id] => 18  
                                                            [pid] => 16  
                                                            [name] => 义源村  
                                                            )  
  
                                                        [1] => Array  
                                                            (  
                                                            [id] => 19  
                                                            [pid] => 16  
                                                            [name] => 上坝村  
                                                            )  
  
                                                        )  
  
                                                )  
  
                                            [1] => Array  
                                                (  
                                                    [id] => 17  
                                                    [pid] => 14  
                                                    [name] => 大田乡  
                                                )  
  
                                            )  
  
                                    )  
  
                                [1] => Array  
                                    (  
                                        [id] => 15  
                                        [pid] => 13  
                                        [name] => 于都县  
                                    )  
  
                            )  
  
                    )  
  
            )  
  
    )  
  
[1] => Array  
    (  
        [id] => 2  
        [pid] => 0  
        [name] => 黑龙江省  
        [son] => Array  
            (  
                [0] => Array  
                    (  
                        [id] => 4  
                        [pid] => 2  
                        [name] => 哈尔滨市  
                        [son] => Array  
                            (  
                            [0] => Array  
                                (  
                                    [id] => 6  
                                    [pid] => 4  
                                    [name] => 香坊区  
                                    [son] => Array  
                                        (  
                                        [0] => Array  
                                            (  
                                                [id] => 8  
                                                [pid] => 6  
                                                [name] => 和兴路  
                                                [son] => Array  
                                                    (  
                                                        [0] => Array  
                                                            (  
                                                            [id] => 10  
                                                            [pid] => 8  
                                                            [name] =>   
                                                             东北林业大学  
                                                            )  
  
                                                        [1] => Array  
                                                            (  
                                                            [id] => 12  
                                                            [pid] => 8  
                                                            [name] =>   
                                                            哈尔滨师范大学  
                                                            )  
  
                                                    )  
  
                                            )  
  
                                        )  
  
                                )  
  
                            [1] => Array  
                                (  
                                    [id] => 7  
                                    [pid] => 4  
                                    [name] => 南岗区  
                                    [son] => Array  
                                        (  
                                        [0] => Array  
                                            (  
                                            [id] => 9  
                                            [pid] => 7  
                                            [name] => 西大直街  
                                            [son] => Array  
                                                (  
                                                [0] => Array  
                                                    (  
                                                    [id] => 11  
                                                    [pid] => 9  
                                                    [name] =>   
                                                     哈尔滨工业大学  
                                                    )  
  
                                                )  
  
                                            )  
  
                                        )  
  
                                )  
  
                            )  
  
                    )  
  
                [1] => Array  
                    (  
                        [id] => 5  
                        [pid] => 2  
                        [name] => 鸡西市  
                    )  
  
            )  
  
    )  
)*  
 
 
通过测试,能够完成所设想的分类无限级,但是,用他自有数据可以,但是用我数据库的数据不可以,会出现错误,比如会出现如下错误:
[php]  
Array  
(  
    [10] => Array  
        (  
            [child] => Array  
                (  
                    [14] =>   
                )  
  
        )  
  
    [11] =>   
    [12] =>   
    [9] => Array  
        (  
            [child] => Array  
                (  
                    [13] =>   
                )  
  
        )  
  
)  
 
只显示数组序号,不显示相应数据,这是我很苦恼,这样测试后能够完全显示:
 
[php]  
function genTree5($items) {   
    foreach ($items as $item) {  
    $items[$item['id']]=$item;//ADD THIS  
        $items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];   
        }  
    return isset($items[0]['son']) ? $items[0]['son'] : array();   
}   
 
但是这只在id升序状态下可以使用,乱序会显示错误
 
虽然在大多情况下id会保持升序状态,但是如果涉及到排序后,遍无法使用了。
之前,CI的吕老师提供了一种高效方法,即:
 
[php] 
id 父id   分级     
1   0      0,1  
2   1     0,1,2  
3   1     0,1,3  
4   3    0,1,3,4  
  
select * from 表  order  by 分级 asc  
 
这个结构,会使分级按照父子顺序排序,首先对第一个0排序,然后对第二个1排序,以此类推,自动分类,十分好用(同时注意,一定要保持有两组,也就是0,1开始或者0,0开始,否则根分级会提前显示)。“分级”也可以叫childid,因为是记录的子id层。
[php]  
|--2  
|----2-1  
|------2-1-1  
|--3  
|----3-1  
|--4  
|--1  
|----1-1  
显示直接遍历即可,因为我有一个depth字段,记录深度,所以能更好的显示。
这个方法运行时间也较短,微秒级运行,总之耗费在数据库排序上了,其他的基本很愉快。
利用指针的一般在没有缓存情况下测试大多数大于排序后的时间,大多数是CPU时间,而且,结果不准确。
 
PS:PHP已经对地址,指针之类的概念弱化了,也就是说,并不是PHP的特点,虽然可以使用,但是会出现一些莫名错误。所以还是老老实实的吧~神马大数据算法,就不用PHP来做了,C++什么的,干这个,比PHP速度快多了。。。。
同时 @Tonton 对他的算法进行修正。
 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/477766.htmlTechArticleCI的seven给我提供了一个方法,如下: [php] ?php /** * 此方法由@Tonton 提供 * http://my.oschina.net/u/918697 * @date 2012-12-12 */ function genTree5($items) { fore...
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

7 Fungsi PHP Saya Menyesal Saya Tidak Tahu Sebelum ini 7 Fungsi PHP Saya Menyesal Saya Tidak Tahu Sebelum ini Nov 13, 2024 am 09:42 AM

Jika anda seorang pembangun PHP yang berpengalaman, anda mungkin merasakan bahawa anda telah berada di sana dan telah melakukannya. Anda telah membangunkan sejumlah besar aplikasi, menyahpenyahpepijat berjuta-juta baris kod dan mengubah suai sekumpulan skrip untuk mencapai op

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Program PHP untuk mengira vokal dalam rentetan Program PHP untuk mengira vokal dalam rentetan Feb 07, 2025 pm 12:12 PM

Rentetan adalah urutan aksara, termasuk huruf, nombor, dan simbol. Tutorial ini akan mempelajari cara mengira bilangan vokal dalam rentetan yang diberikan dalam PHP menggunakan kaedah yang berbeza. Vokal dalam bahasa Inggeris adalah a, e, i, o, u, dan mereka boleh menjadi huruf besar atau huruf kecil. Apa itu vokal? Vokal adalah watak abjad yang mewakili sebutan tertentu. Terdapat lima vokal dalam bahasa Inggeris, termasuk huruf besar dan huruf kecil: a, e, i, o, u Contoh 1 Input: String = "TutorialSpoint" Output: 6 menjelaskan Vokal dalam rentetan "TutorialSpoint" adalah u, o, i, a, o, i. Terdapat 6 yuan sebanyak 6

Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Feb 07, 2025 am 11:57 AM

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

Terangkan pengikatan statik lewat dalam php (statik: :). Terangkan pengikatan statik lewat dalam php (statik: :). Apr 03, 2025 am 12:04 AM

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Apakah kaedah Magic PHP (__construct, __destruct, __call, __get, __set, dll) dan menyediakan kes penggunaan? Apakah kaedah Magic PHP (__construct, __destruct, __call, __get, __set, dll) dan menyediakan kes penggunaan? Apr 03, 2025 am 12:03 AM

Apakah kaedah sihir PHP? Kaedah sihir PHP termasuk: 1. \ _ \ _ Membina, digunakan untuk memulakan objek; 2. \ _ \ _ Destruct, digunakan untuk membersihkan sumber; 3. \ _ \ _ Call, mengendalikan panggilan kaedah yang tidak wujud; 4. \ _ \ _ Mendapatkan, melaksanakan akses atribut dinamik; 5. \ _ \ _ Set, melaksanakan tetapan atribut dinamik. Kaedah ini secara automatik dipanggil dalam situasi tertentu, meningkatkan fleksibiliti dan kecekapan kod.

See all articles