Ajax异步请求PHP数据,ajax异步php
来源:http://www.ido321.com/1138.html
接到了老师的一个作业,实现的布局如图:
如果输入了科室ID,科室名字只显示与ID对应的,若没有输入,则显示全部,然后根据I科室名字的值,在所属大科中的文本框自动显示科室名字所在的大科。例如:选择了心血管内科,则在所属大科显示内科。
主要代码如下:
根据ID请求科室
<span>function</span><span> showHint(str) { <span>var</span> xmlhttp; <span>if</span> (window.XMLHttpRequest) {<span>// IE7+, Firefox, Chrome, Opera, Safari</span> xmlhttp=<span>new</span> XMLHttpRequest(); } <span>else</span> {<span>// IE6, IE5</span> xmlhttp=<span>new</span> ActiveXObject(<span>"Microsoft.XMLHTTP"</span>); } xmlhttp.onreadystatechange=<span>function</span>() { <span>if</span> (xmlhttp.readyState==4 && xmlhttp.status==200) { document.getElementById(<span>"txtHint"</span>).innerHTML=xmlhttp.responseText; } } xmlhttp.open(<span>"GET"</span>,<span>"keshi.php?q="</span>+str,<span>true</span>); xmlhttp.send(); }</span>
keshi.php:
<span><?php <span>/*防止恶意调用*/</span> define(<span>"TEST"</span>,<span>'test'</span>); <span>// 引入文件</span> <span>include_once</span> <span>'mysql.func.php'</span>; <span>// 数据库初始化</span> connectMySQL(); selectDB(); setZiFuJi(); <span>//获得来自 URL 的 q 参数</span> $q=$_GET[<span>"q"</span>]; <span>//如果 q 是数字或者数字字符串</span> <span>if</span> (is_numeric($q)) { $q = intval($q); $hint=<span>""</span>; $resultDKQ = queryDB(<span>"select name from table_dake where id=$q"</span>); $hint = <span>'科室名字:<select name="ksname" id="ksname" onchange="show(this.options[this.selectedIndex].value)">'</span>; <span>while</span> (!!$rowDKQ = fetchAssoc($resultDKQ)) { $hint .= <span>'<optgroup label='</span>.$rowDKQ[<span>'name'</span>].<span>'>'</span>; $resultKSQ = queryDB(<span>"select table_dake.id,table_keshi.sid,table_keshi.name from table_dake,table_keshi where table_dake.name='{$rowDKQ['name']}' and table_keshi.sid=table_dake.id"</span>); <span>while</span>(!!$rowKSQ = fetchAssoc($resultKSQ)) { $hint .= <span>'<option>'name'</span>].<span>'>'</span>.$rowKSQ[<span>'name'</span>].<span>'</option>'</span>; } $hint .= <span>'</optgroup>'</span>; } } <span>// 不是数字</span> <span>else</span> { $resultDK = queryDB(<span>"select table_dake.name from table_dake"</span>); $hint = <span>'科室名字:<select name="ksname" id="ksname" onchange="show(this.options[this.selectedIndex].value)">'</span>; <span>while</span> (!!$rowDK = fetchAssoc($resultDK)) { $hint .= <span>'<optgroup label='</span>.$rowDK[<span>'name'</span>].<span>'>'</span>; $resultKS = queryDB(<span>"select table_dake.id,table_keshi.sid,table_keshi.name from table_dake,table_keshi where table_dake.name='{$rowDK['name']}' and table_keshi.sid=table_dake.id"</span>); <span>while</span>(!!$rowKS = fetchAssoc($resultKS)) { $hint .= <span>'<option>'name'</span>].<span>'>'</span>.$rowKS[<span>'name'</span>].<span>'</option>'</span>; } $hint .= <span>'</optgroup>'</span>; } } $response=$hint; <span>//输出响应</span> <span>echo</span> $response; ?></span>
效果:
未输入ID如上图,输入ID在下图:
下一篇:百家搜索:在网站中添加Google、百度等搜索引擎
在S端直接ECHO '字符串';或 EXIT(json_encode(数组));就行了,
每次请求是没问题的,但是每次请求肯定会有延时。异步的问题只是会有延时,不会存在接收不到返回值的问题,收不到返回值肯定是你哪里写错了。
同时你这个情况我的比较建议一次就把数据都请求过来,存在客户端这边,然后根据需要显示就可以了。
希望对你有帮助!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

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