微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jQuery+PHP+MySQL二级联动下拉菜单实例讲解

二级联动下拉菜单选择应用在在很多地方,比如说省市下拉联动,商品大小类下拉选择联动。本文将通过实例讲解使用jQuery+PHP+MysqL来实现大小分类二级下拉联动效果实现效果:当选择大类时,小类下拉框里的选项内容也随着改变。

根据大类的值,通过jQuery把值传给后台PHP处理,PHP通过查询MysqL数据库,得到相应的小类,并返回JSON数据给前端处理。

XHTML

首先我们要建立两个下拉选择框,第一个是大类,第二个是小类。大类的值可以是预先写好,也可以是从数据库读取。

rush:xhtml;">

jQuery

先写一个函数获取大类选择框的值,并通过$.getJSON方法传递给后台server.PHP,读取后台返回的JSON数据,并通过$.each方法遍历JSON数据,将对应的值写入一个option字符串,最后将option追加到小类里。

rush:js;"> function getSelectVal(){ $.getJSON("server.PHP",{bigname:$("#bigname").val()},function(json){ var smallname = $("#smallname"); $("option",smallname).remove(); //清空原有的选项 $.each(json,function(index,array){ var option = ""; smallname.append(option); }); }); }

注意,在遍历JSON数据追加之前一定要先将小类里的原有的项清空。清空选项的方法有两种,一种是上文代码中提到,还有一种更简单直接的方法

rush:js;"> smallname.();

然后,在页面载入后执行调用函数

rush:js;"> $(function(){ getSelectVal(); $("#bigname").change(function(){ getSelectVal(); }); });

页面初始的时候,下拉框是要设置选项的,所以在初始的时候就要调用getSelectVal(),而当大类选项改变时,也调用了getSelectVal()。

PHP

$bigid = $_GET["bigname"];
if(isset($bigid)){
$q=mysql_query("select * from catalog where cid = $bigid");
while($row=mysql_fetch_array($q)){
$select[] = array("id"=>$row[id],"title"=>$row[title]);
}
echo json_encode($select);
}

根据jQuery传递过来的大类的value值,构造sql语句查询分类表,最终输出JSON数据。本站在未做特别说明的情况下所使用的PHPMysqL连接,和查询语句等均使用原始语句方法MysqL_query等,目的就是为了让读者能够直观的知晓数据的传输查询。 最后附上MysqL表结构:

rush:sql;"> CREATE TABLE `catalog` ( `id` mediumint(6) NOT NULL auto_increment,`cid` mediumint(6) NOT NULL default '0',`title` varchar(50) NOT NULL,PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;

以上就是介绍了jQuery+PHP+MysqL三者结合如何实现的二级联动下拉菜单,程序还有一些不足之处,需要继续完善,希望本文可以给大家一点启发。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐