好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > JavaScript結合PHP實現網頁制作中雙下拉菜單的動態實現

JavaScript結合PHP實現網頁制作中雙下拉菜單的動態實現

熱門標簽:好操作的電話機器人廠家 南昌市地圖標注app 南京新思維電話機器人 泰州泰興400電話 怎么申請 企業怎么在聯通申請400電話 聊城智能電銷機器人外呼 如何用中國地圖標注數字點 地圖標注市場怎么樣 百度地圖添加標注圖標樣式

本文介紹了雙下拉菜單的動態實現的代碼,例如:在主菜單中有“焦點新聞”、“生活時尚”、“心情故事”三個選項,通過“焦點新聞”的選擇,子菜單自動生成如“國內”、“國際”、“體育”、“文娛”,依此類推。

利用javascript,我們可以輕松實現上述效果。但問題是,如果菜單中的選項是從數據庫(或其他文件)中動態提取,實現起來就并不是輕而易舉的了。筆者根據自己的實際經驗,向大家介紹一種利用javascript + php的實現方法,文中的數據庫采用mysql。在本例中,筆者還將介紹在每一次表單提交之后,如何返回上一次菜單選項的選擇狀態。

文章中所介紹的php的作用,一是用來從數據庫中提取菜單選項,另一作用,就是用來生成javascript代碼。讀者可以采用自己熟悉的解釋型語言,如asp。

為了簡化代碼,假設主菜單已經通過html構造,由于子菜單需要動態設計,所以只繪制了基本框架,html代碼如下:

select name="mmenu" onchange="java script:setmenu()"> //主菜單設計 
 
option value="a">焦點新聞/option> 
 
option value="b">生活時尚/option> 
 
option value="c">心情故事/option> 
 
//value必須與下文的menu數組相一致 
 
/select> 
 
select name="smenu"> //子菜單設計 
 
/select> 

 我們需要考慮的是,菜單的onchange()事件需要完成哪些步驟。其大致過程是,根據主菜單的選項,構造子菜單項目。而子菜單的項目文字最好事先設定。根據這個思路,筆者采用了javascript中的聯合數組記錄子菜單選項,并由php在加載時自動生成。由此,筆者設計了如下的javascript函數setmenu(): 

function setmenu(){ 
 
menu=array("a","b","c"); //構造menu聯合數組 

?php //開始php程序 
 
$db = new my_db(); 
 
$db->database = "***"; //構造新的mysql連接,這里使用了phplib 
 
$mmenu = array("a","b","c"); //這里筆者作了簡化 
 
for ($i=0;$icount($mmenu);$i++){ 
 
$id = $mmenu[$i]; 
 
$db->query("select menu from class where menuid ='".$id."'"); 
 
//假設菜單選項存放在class表的menu字段,menuid用來標識menu 
 
while ($db->next_record()){ 
 
$smenu[] = """.$db->f("menu")."""; 
 
} 
 
if (isset($smenu)  is_array($smenu)){ 
 
$str = implode(",",$smenu); 
 
echo "menu["$id"] =array($str);ntt"; 
 
//完成menu聯合數組的填充 
 
unset($smenu); //刪除smenu變量 
 
} 
 
} 
 
?> //結束php程序 
with (document) { 
 
id=all("mmenu").value; //獲得主菜單的value值 
 
arr_menu=menu[id]; 
 
for(i=all("smenu").options.length;i>=0;i--){ 
 
all("smenu").options.remove(i); //需要清除原有的項目 
 
} 
 
if (arr_menu.length==0){ 
 
return; 
 
} 
 
for(i=0;iarr_menu.length;i++){ 
 
obj=createelement("option"); 
 
obj.text=arr_class[i]; 
 
all("smenu").options.add(obj); 
 
} 
 
} 

這樣每次顯示文檔時,php部分將解釋為javascript語言,當單擊主菜單時,子菜單將自動更新。同樣道理,讀者可以根據此思路,創造更復雜的多重菜單選項。 

最后,筆者簡要介紹一下,如何實現在表單提交后,仍然保持菜單項上一次的狀態。技巧其實很多,而筆者采用的是隱含變量法。在表單中添加如下代碼: 

input type="hidden" name="h1"> 
 
input type="hidden" name="h2"> 

 我們只需要在form表單的onsubmit()事件中給每個隱含變量賦值即可。即:  

document.all("h1").value=document.all("mmenu").selectedindex; 
 
document.all("h2").value=document.all("smenu").selectedindex; 

為了利用隱含變量,在文檔的body的onload()事件中,我們利用php方法(也可用其它方法)來控制菜單的顯示: 

?php 
 
if (!isset($h1)){ //只需要判斷$h1 
 
$h1 = 0; 
 
$h2 = 0; 
 
} 
 
echo "document.all("mmenu").selectedindex=".$h1.";ntt"; 
 
echo "document.all("mmenu").click();ntt"; 
 
echo "document.all("mmenu").selectedindex=".$h1.";ntt"; 
 
echo "document.all("smenu").selectedindex=".$h2; 
 
?> 

至此,我們已經實現雙下拉菜單的動態實現方法。

您可能感興趣的文章:
  • PHP導航下拉菜單的實現如此簡單
  • thinkphp實現面包屑導航(當前位置)例子分享
  • php實現面包屑導航例子分享
  • php可應用于面包屑導航的遞歸尋找家譜樹實現方法
  • 簡單的用PHP編寫的導航條程序
  • ThinkPHP使用心得分享-ThinkPHP + Ajax 實現2級聯動下拉菜單
  • jQuery+PHP+MySQL二級聯動下拉菜單實例講解
  • php 三級聯動菜單
  • 用php+javascript實現二級級聯菜單的制作
  • PHP+JS三級菜單聯動菜單實現方法
  • php+jQuery實現的三級導航欄下拉菜單顯示效果

標簽:烏蘭察布 臨汾 吉林 銅川 白銀 自貢 山南 開封

巨人網絡通訊聲明:本文標題《JavaScript結合PHP實現網頁制作中雙下拉菜單的動態實現》,本文關鍵詞  JavaScript,結合,PHP,實現,網頁制作,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《JavaScript結合PHP實現網頁制作中雙下拉菜單的動態實現》相關的同類信息!
  • 本頁收集關于JavaScript結合PHP實現網頁制作中雙下拉菜單的動態實現的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 韩国good电影| 乱Lun合集1第10部分阅读| 久久国产亚洲电影天堂| 一级片特黄| 天天夜日日日日碰日日摸| yy6080琪琪A片影院| 男男车车好快的车车cp动漫| 福利电影网址| 熟女?人妻?人妻のAV网站| 狠狠色噜噜噜噜狠狠狠狠狠狠奇米 | 男人摸女人胸| 96pao强力打造免费高速高| 久久亚洲综合国产精品99麻豆怎么下载| 亚洲综合国产一区二区三区| 欧美头像| 高级秘密俱乐部的娇妻| 国严产品自偷自偷在线观看| 利智全身棵| 亚洲天堂美女视频| 韩国一级婬乱片A片| 欧美成人影院在线播放| 美女逼逼视频| 三级毛片在线| 精品日韩欧美一区二区三区| 亚州AⅤ日韩AV色欲Av一日久| 成年美女黄网站色奶头大全av| 二四六免费资料大全集| 老师腿开大点我添添公视频| 一级特黄大片,视频| 国产一级二级AV女免费| 亚洲欧美日韩第一页| 狠狠色丁香久久婷婷| ysl蜜桃色888网站| 三级古装野外农村妇| 日韩三级网址| 野花日本完整版免费观看2019| 国产精品久久久天天影视香蕉| Japanese高潮喷水抽搐| 在线黄视频| 女扒开腿秘?爽桶动漫| 老师扒开裙子让我爽个够|