六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

JavaScript+PHP 應用一:頁面制作中雙下拉菜單的動態完成(轉貼)

[摘要]JavaScript+PHP 應用一:網頁制作中雙下拉菜單的動態實現---摘自互聯網在網頁制作中,常常遇到這種情況,通過主下拉菜單的選擇,動態的生成子下拉菜單。例如:在主菜單中有“焦點新聞”、“生活時尚”、“心情故事”三個選項,通過“焦點新聞”的選擇,子菜單自動生成如“國內”、“國際”、“體育”、...
JavaScript+PHP 應用一:網頁制作中雙下拉菜單的動態實現

---摘自互聯網

在網頁制作中,常常遇到這種情況,通過主下拉菜單的選擇,動態的生成子下拉菜單。例如:在主菜單中有“焦點新聞”、“生活時尚”、“心情故事”三個選項,通過“焦點新聞”的選擇,子菜單自動生成如“國內”、“國際”、“體育”、“文娛”,依此類推。

利用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;

?>

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



主站蜘蛛池模板: 日韩去日本高清在线 | 色综合手机在线 | 色婷婷啪啪| 日韩 欧美 中文 亚洲 高清 在线 | 亚洲最大色网站 | 日日摸日日干 | 亚洲国产欧美在线人成app | 欧美一级久久 | 日本亚洲中午字幕乱码 | 亚洲精品日本 | 日日干夜夜操 | 天美传媒麻豆自制剧 | 色橹橹欧美在线观看视频高清 | 色天天天天| 日韩孕交| 日韩欧美一区二区三区不卡视频 | 又爽又黄无遮挡高清免费视频 | 亚洲欧美日韩国产精品一区 | 性感美女视频黄.免费网站 性感保姆正片 | 四虎精品免费永久在线 | 午夜视频在线免费播放 | 日本成人在线免费观看 | 色婷婷天天综合在线 | 日韩h | 亚洲第一网站快活影院 | 日韩一区二区三区四区不卡 | 亚洲video | 伊在线视频| 亚洲精品欧美综合 | 我想看一级播放片一级的 | 欧美小视频在线 | 最新亚洲情黄在线网站无广告 | 三级特黄高清完整视频 | 日韩精品一区二区三区乱码 | 天天摸天天碰天天碰 | 亚洲a视频在线观看 | 亚洲免费在线视频 | 欧美专区第一页 | 亚洲第一区二区快射影院 | 伊人久久大香线蕉观看 | 天天操天天操天天操 |