mysql - PHP三级导航菜单
实在不知道怎么做了 不知道哪位大师帮个忙 实在着急啊!
效果:
-- 表的结构 arctype
CREATE TABLE arctype
(id
smallint(5) unsigned NOT NULL auto_increment,parid
smallint(5) unsigned NOT NULL default '0',typerank
smallint(5) unsigned NOT NULL default '0',typename
char(15) NOT NULL,typedir
char(15) default NULL,typetitle
varchar(80) NOT NULL,typekeyword
varchar(120) NOT NULL,typedescription
varchar(150) NOT NULL,
PRIMARY KEY (id
)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=176 ;
INSERT INTO arctype
VALUES (145, 0, 1, '语法', 'yufa', '德语语法的在线学习 ', '德语语法学习,德语语法在线学习,德语语法练习,德语语法音频,德语语法视频', '我们提供德语语法的在线学习,德语语法学习最好的网站 ');
INSERT INTO arctype
VALUES (164, 145, 0, '格的用法', 'ge', '德语格的用法,德语格的用法在线学习,德语格的用法入门,德语格的用法视频,德语格的用法音频', '德语格的用法,德语格的用法在线学习,德语格的用法入门,德语格的用法视频,德语格的用法音频', '我们提供德语格的用法的在线学习,德语格的用法学习最好的网站 ');
INSERT INTO arctype
VALUES (165, 164, 0, '一格', 'yige', '德语格的用法--一格在线学习 ', '德语一格,德语一格在线学习,德语一格入门,德语一格视频,德语一格音频', '我们提供德语一格语法的在线学习,德语一格语法学习最好的网站 ');
INSERT INTO arctype
VALUES (166, 164, 0, '二格', 'erge', '德语格的用法--二格在线学习 ', '德语二格,德语二格在线学习,德语二格入门,德语二格视频,德语二格音频', '我们提供德语二格语法的在线学习,德语二格语法学习最好的网站 ');
INSERT INTO arctype
VALUES (167, 164, 0, '三格', 'sange', '德语格的用法--三格在线学习 ', '德语三格,德语三格在线学习,德语三格入门,德语三格视频,德语三格音频', '我们提供德语三格语法的在线学习,德语三格语法学习最好的网站 ');
INSERT INTO arctype
VALUES (168, 164, 0, '四格', 'sige', '德语格的用法--四格在线学习 ', '德语四格,德语四格在线学习,德语四格入门,德语四格视频,德语四格音频', '我们提供德语四格语法的在线学习,德语四格语法学习最好的网站 ');
麻烦别简单的写用js 用ajax 或者js循环 这个我也知道,问题是我对于ajax和js不是太懂!所以还请各位大神帮忙写下,再次谢过!
回复内容:
实在不知道怎么做了 不知道哪位大师帮个忙 实在着急啊!
效果:
-- 表的结构 arctype
CREATE TABLE arctype
(id
smallint(5) unsigned NOT NULL auto_increment,parid
smallint(5) unsigned NOT NULL default '0',typerank
smallint(5) unsigned NOT NULL default '0',typename
char(15) NOT NULL,typedir
char(15) default NULL,typetitle
varchar(80) NOT NULL,typekeyword
varchar(120) NOT NULL,typedescription
varchar(150) NOT NULL,
PRIMARY KEY (id
)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=176 ;
INSERT INTO arctype
VALUES (145, 0, 1, '语法', 'yufa', '德语语法的在线学习 ', '德语语法学习,德语语法在线学习,德语语法练习,德语语法音频,德语语法视频', '我们提供德语语法的在线学习,德语语法学习最好的网站 ');
INSERT INTO arctype
VALUES (164, 145, 0, '格的用法', 'ge', '德语格的用法,德语格的用法在线学习,德语格的用法入门,德语格的用法视频,德语格的用法音频', '德语格的用法,德语格的用法在线学习,德语格的用法入门,德语格的用法视频,德语格的用法音频', '我们提供德语格的用法的在线学习,德语格的用法学习最好的网站 ');
INSERT INTO arctype
VALUES (165, 164, 0, '一格', 'yige', '德语格的用法--一格在线学习 ', '德语一格,德语一格在线学习,德语一格入门,德语一格视频,德语一格音频', '我们提供德语一格语法的在线学习,德语一格语法学习最好的网站 ');
INSERT INTO arctype
VALUES (166, 164, 0, '二格', 'erge', '德语格的用法--二格在线学习 ', '德语二格,德语二格在线学习,德语二格入门,德语二格视频,德语二格音频', '我们提供德语二格语法的在线学习,德语二格语法学习最好的网站 ');
INSERT INTO arctype
VALUES (167, 164, 0, '三格', 'sange', '德语格的用法--三格在线学习 ', '德语三格,德语三格在线学习,德语三格入门,德语三格视频,德语三格音频', '我们提供德语三格语法的在线学习,德语三格语法学习最好的网站 ');
INSERT INTO arctype
VALUES (168, 164, 0, '四格', 'sige', '德语格的用法--四格在线学习 ', '德语四格,德语四格在线学习,德语四格入门,德语四格视频,德语四格音频', '我们提供德语四格语法的在线学习,德语四格语法学习最好的网站 ');
麻烦别简单的写用js 用ajax 或者js循环 这个我也知道,问题是我对于ajax和js不是太懂!所以还请各位大神帮忙写下,再次谢过!
直接做无限分类。还在在乎什么3级导航。
无限分类目前实行方法非常多。
我一般就直接做一个无限分类。sql语句一查就全部出来了。要什么有什么。
不好意思呀。开始没看你的代码。不是太难吧。
看了下你的数据库表。基本就是非常老套的设计了一个ID 字段。然后有一个PID字段。然后根据相同的PID来取值!是这个思路对吧。
做法可以很多啦。不行循环查询数据库就交表。多次和自身join出结果。
如果觉得麻烦。就多次查询。每次要查那个的全部孩子就去查出来。然后循环去查!Ajax做也基本是这个思路。不过我不太喜欢这种数据库设计方式。
建议你去搜索一下adjacent list model
和nested set model 。大概10年前吧!这些问题就已经不是问题了。你用的第一种adjacency list 就是最简单的做法。优点是插入。更新。删除简单。确定就在查询上。当然啦。楼主有兴趣的话还可以搜索martieral path。以及更加复杂的matrix encoding。这些模型在无限分类的实现上以及非常成熟。看完回头看楼主的问题。也许。你就会说。哇。原来这么简单。
直接上点参考代码吧~
PHP简单实现无限极分类

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

MySQL convient aux débutants car il est simple à installer, puissant et facile à gérer les données. 1. Installation et configuration simples, adaptées à une variété de systèmes d'exploitation. 2. Prise en charge des opérations de base telles que la création de bases de données et de tables, d'insertion, d'interrogation, de mise à jour et de suppression de données. 3. Fournir des fonctions avancées telles que les opérations de jointure et les sous-questionnaires. 4. Les performances peuvent être améliorées par l'indexation, l'optimisation des requêtes et le partitionnement de la table. 5. Prise en charge des mesures de sauvegarde, de récupération et de sécurité pour garantir la sécurité et la cohérence des données.

Navicat lui-même ne stocke pas le mot de passe de la base de données et ne peut récupérer que le mot de passe chiffré. Solution: 1. Vérifiez le gestionnaire de mots de passe; 2. Vérifiez la fonction "Remember Motway" de Navicat; 3. Réinitialisez le mot de passe de la base de données; 4. Contactez l'administrateur de la base de données.

Créez une base de données à l'aide de NAVICAT Premium: Connectez-vous au serveur de base de données et entrez les paramètres de connexion. Cliquez avec le bouton droit sur le serveur et sélectionnez Créer une base de données. Entrez le nom de la nouvelle base de données et le jeu de caractères spécifié et la collation. Connectez-vous à la nouvelle base de données et créez le tableau dans le navigateur d'objet. Cliquez avec le bouton droit sur le tableau et sélectionnez Insérer des données pour insérer les données.

NAVICAT pour MARIADB ne peut pas afficher directement le mot de passe de la base de données car le mot de passe est stocké sous forme cryptée. Pour garantir la sécurité de la base de données, il existe trois façons de réinitialiser votre mot de passe: réinitialisez votre mot de passe via Navicat et définissez un mot de passe complexe. Affichez le fichier de configuration (non recommandé, haut risque). Utilisez des outils de ligne de commande système (non recommandés, vous devez être compétent dans les outils de ligne de commande).

Raisons courantes pour lesquelles Navicat ne peut pas se connecter à la base de données et à ses solutions: 1. Vérifiez l'état d'exécution du serveur; 2. Vérifiez les informations de connexion; 3. Réglez les paramètres du pare-feu; 4. Configurer l'accès à distance; 5. Dépannage des problèmes de réseau; 6. Vérifier les autorisations; 7. Assurer la compatibilité de la version; 8. Dépannage d'autres possibilités.

Vous pouvez créer une nouvelle connexion MySQL dans NAVICAT en suivant les étapes: ouvrez l'application et sélectionnez une nouvelle connexion (CTRL N). Sélectionnez "MySQL" comme type de connexion. Entrez l'adresse Hostname / IP, le port, le nom d'utilisateur et le mot de passe. (Facultatif) Configurer les options avancées. Enregistrez la connexion et entrez le nom de la connexion.

Erreurs et solutions courantes Lors de la connexion aux bases de données: nom d'utilisateur ou mot de passe (erreur 1045) Blocs de pare-feu Connexion (erreur 2003) Délai de connexion (erreur 10060) Impossible d'utiliser la connexion à socket (erreur 1042) Erreur de connexion SSL (erreur 10055) Trop de connexions Résultat de l'hôte étant bloqué (erreur 1129)

Pour se connecter à une base de données MySQL locale à l'aide de NAVICAT: créez une connexion et définissez le nom de connexion, l'hôte, le port, le nom d'utilisateur et le mot de passe. Testez la connexion pour vous assurer que les paramètres sont corrects. Enregistrez la connexion. Sélectionnez une nouvelle connexion dans la liste de connexions. Double-cliquez sur la base de données à laquelle vous souhaitez vous connecter.
