php+mysql实现的二级联动菜单效果详解,mysql联动
本文实例讲述了php+mysql实现的二级联动菜单效果。分享给大家供大家参考,具体如下:
<!--php+mysql二级联动--> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>生成学院专业级联下拉菜单测试 </title> </head> <body> <? // /*********************************************** ** 功 能: php+mysql+javascript实现学院专业二级级联下拉框 ** 数据库:数据库名( dms)、数据表( colleges、 majors) ** 表 colleges中字段: college_id( id编号)、 name(学院名) ** 表 majors中的字段: major_id( id编号)、 college_id(学院 ID)、 name(学院名) ** version 1.0 ** 作 者: wu yaowen ***********************************************/ //****************** 连接选择数据库 *************** $link = mysql_connect("localhost", "root", "123456") or die("Could not connect : " . mysql_error()); mysql_select_db("dms") or die("Could not select database"); //******************提取学院信息 ****************** $queryCol = "select * from colleges order by college_id "; mysql_query("SET NAMES 'gb2312'"); $result1 = mysql_query($queryCol) or die("Query failed : " . mysql_error()); $colleges = array(); while( $row1 = mysql_fetch_array($result1) ) { $colleges[] = $row1; } //print_r ($forum_data); mysql_free_result($result1); //**************获取专业信息 ************** $queryMaj = "select * from majors order by college_id desc"; mysql_query("SET NAMES 'gb2312'"); if( !($result2 = mysql_query($queryMaj)) ) { die('Could not query t_city list'); } $majors = array(); while( $row2 = mysql_fetch_array($result2) ) { $majors[] = $row2; } mysql_free_result($result2); ?> <!--************ JavaScript处理 college-onChange *************--> <script language = "JavaScript"> var majorCount; // 存储专业记录条数 // form_majors[] 储存专业 major数据,如 {(1,1,电子商务 ),(4,1,计算机科学 ),(3,2,古典文学 )} form_majors = new Array(); <?php $num2 = count($majors); // $num2 获取专业表中记录的个数 ?> majorCount = <?php echo $num2;?>; <? for($j=0;$j<$num2;$j++) // 从 0开始取出上面 majors[]中存储的专业数据填充数组 { ?> form_majors[<?echo $j;?>] = new Array("<?echo $majors[$j]['major_id'];?>","<?echo $majors[$j]['college_id'];?>","<?echo $majors[$j]['name'];?>"); <?php } ?> function changeCollege(college_id) { document.stu_add_form.major.length = 0; var id=id; var j; document.stu_add_form.major.options[0] = new Option('==选择专业 ==',''); // label的 value为空 ' ' for (j=0;j < majorCount; j++) // 从 0开始判断 { if (form_majors[j][1] == college_id) // if college_id等于选择的学院的 id { document.stu_add_form.major.options[document.stu_add_form.major.length] = new Option(form_majors[j][2], form_majors[j][0]); } } } </script> <!--********************页面表单 *************************--> <form name="stu_add_form" method="post"> 选择: <select name="college" onChange="changeCollege(document.stu_add_form.college.options[document.stu_add_form.college.selectedIndex].value)" size="1"> <option selected>==请选择学院 ==</option> <?php $num = count($colleges); for($i=0;$i<$num;$i++) { ?> <option value="<?echo $colleges[$i]['college_id'];?>"><?echo $colleges[$i]['name'];?></option> <? } ?> </select> <select name="major"> <option selected value="">==选择专业 ==</option> </select> </form> </body> </html>
sql语句:
-- -- 表的结构 `colleges` -- CREATE TABLE IF NOT EXISTS `colleges` ( `college_id` int(8) NOT NULL auto_increment COMMENT '学院编号自动增加', `name` varchar(40) NOT NULL COMMENT '学院名称', PRIMARY KEY (`college_id`), UNIQUE KEY `name` (`name`) ) ENGINE=InnoDB DEFAULT CHARSET=gb2312 AUTO_INCREMENT=7 ; -- -- 导出表中的数据 `colleges` -- INSERT INTO `colleges` (`college_id`, `name`) VALUES (4, '化学与化工学院'), (1, '计算机与信息科学学院'), (6, '美术学院'), (2, '文学院'), (5, '音乐学院'), (3, '政治与公共管理学院'); -- -- 表的结构 `majors` -- CREATE TABLE IF NOT EXISTS `majors` ( `major_id` int(8) NOT NULL auto_increment COMMENT '专业号,自动增加', `name` varchar(40) NOT NULL COMMENT '专业名', `college_id` int(8) default NULL COMMENT '所在学院', `counsellor_id` int(10) default NULL COMMENT '辅导员', PRIMARY KEY (`major_id`), UNIQUE KEY `college_id` (`college_id`,`counsellor_id`) ) ENGINE=InnoDB DEFAULT CHARSET=gb2312 AUTO_INCREMENT=8 ; -- -- 导出表中的数据 `majors` -- INSERT INTO `majors` (`major_id`, `name`, `college_id`, `counsellor_id`) VALUES (1, '电子商务', 1, 1), (2, '音乐视唱', 5, 1), (3, '古典文学', 2, 1), (4, '计算机科学', 1, NULL), (5, '自动化', 1, NULL), (6, '现代文学', 2, NULL), (7, '新闻写作', 2, NULL);
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP基于pdo操作数据库技巧总结》、《PHP+MongoDB数据库操作技巧大全》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Dreamweaver Mac版
시각적 웹 개발 도구
