麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JSP > 正文

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

2024-09-05 00:22:43
字體:
來源:轉載
供稿:網友

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

利用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;$i<count($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;i<arr_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;  ?> 

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


注:相關教程知識閱讀請移步到JSP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美日韩影视 | 欧美国产一区二区三区 | 欧美一级黄色录相 | 日本中文视频 | 欧美成人理论片乱 | 亚洲五码在线观看视频 | 最新av在线播放 | 中日韩免费视频 | 美国黄色小视频 | 国产精品99久久久久久久 | 毛片免费视频播放 | 最新av在线播放 | 少妇一级淫片免费放4p | 亚洲欧美国产高清 | 91精品国产乱码久久桃 | 全黄性性激高免费视频 | 国产艳妇av视国产精选av一区 | 免费在线观看成人网 | 日本网站一区二区三区 | 久久精品23 | 日韩美香港a一级毛片免费 日韩激情 | 欧美精品成人一区二区在线观看 | 成人毛片100部 | 国产婷婷一区二区三区 | 羞羞视频免费观看网站 | 成人免费福利 | 粉嫩粉嫩一区二区三区在线播放 | 一级片九九 | 久久亚洲一区二区三区成人国产 | www.17c亚洲蜜桃 | 双性精h调教灌尿打屁股的文案 | 免费久久久 | 毛片三区| 日韩一级免费毛片 | 成人福利在线播放 | 中文字幕在线观看网址 | 日韩一级毛毛片 | 黄色免费电影网址 | 国产精品久久久久久模特 | 狠狠久久伊人中文字幕 | 久草在线观看福利视频 |