js動態的把左邊列表添加到右邊,可上下移動。

来源:http://www.cnblogs.com/yangzailu/archive/2016/11/17/6072440.html
-Advertisement-
Play Games

...


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
  <title> new document </title>
  <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
  <meta name="author" content="" />
  <meta name="keywords" content="" />
  <meta name="description" content="" />
  <link rel="stylesheet" type="text/css" href="" />
  <style type="text/css"></style>
  <script type="text/javascript"></script>
  <META NAME="Description" CONTENT="Power by hill"> 
 </head>
 <body>


<p>選定一項或多項然後點擊添加或移除(按住shift或ctrl可以多選),或在選擇項上雙擊進行添加和移除。</p> 
<form method="post" name="myform"> 
<table border="0" width="300"> 
    <tr> 
            <td width="40%"> 
                    <select style="WIDTH:100%" multiple name="list1" size="12" ondblclick="moveOption(document.myform.list1, document.myform.list2)"> 
                            <option value="北京">北京</option> 
                            <option value="上海">上海</option> 
                            <option value="山東">山東</option> 
                            <option value="安徽">安徽</option> 
                            <option value="重慶">重慶</option> 
                            <option value="福建">福建</option> 
                            <option value="甘肅">甘肅</option> 
                            <option value="廣東">廣東</option> 
                            <option value="廣西">廣西</option> 
                            <option value="貴州">貴州</option> 
                            <option value="海南">海南</option> 
                            <option value="河北">河北</option> 
                            <option value="黑龍江">黑龍江</option> 
                    </select> 
            </td> 

            <td width="20%" align="center"> 
                <input type="button" value="添加" onclick="moveOption(document.myform.list1, document.myform.list2)">
                <br/> 
                <br/> 
                <input type="button" value="刪除" onclick="moveOption(document.myform.list2, document.myform.list1)"> 
            </td> 

            <td width="40%"> 
                <select style="WIDTH:100%" multiple name="list2" size="12" ondblclick="moveOption(document.myform.list2, document.myform.list1)"> 
                </select> 
            </td> 

            <td> 
                <button onclick="changepos(list2,-1)" type="button">上移</button> 
            <br/> 
            <button onclick="changepos(list2,1)" type="button">下移</button> 
            </td> 
    </tr> 
</table> 
值:<input type="text" name="city" size="40"> 
</form> 
<script language="JavaScript"> 
        function moveOption(e1, e2){ 
            try{ 
                    for(var i=0;i<e1.options.length;i++){ 
                        if(e1.options[i].selected){ 
                            var e = e1.options[i]; 
                                e2.options.add(new Option(e.text, e.value)); 
                                    e1.remove(i); 
                                        ii=i-1 
                                } 
                          } 
        document.myform.city.value=getvalue(document.myform.list2); 
                    } 
        catch(e){} 
            } 

        function getvalue(geto){ 
            var allvalue = ""; 
                for(var i=0;i<geto.options.length;i++){ 
                        allvalue +=geto.options[i].value + ","; 
                    } 
                return allvalue; 
             } 

        function changepos(obj,index) { 
            if(index==-1){ 
                    if (obj.selectedIndex>0){ 
                        obj.options(obj.selectedIndex).swapNode(obj.options(obj.selectedIndex-1)) 
                        } 
               } else if(index==1){ 
                        if (obj.selectedIndex<obj.options.length-1){ 
                                obj.options(obj.selectedIndex).swapNode(obj.options(obj.selectedIndex+1)) 
                                 } 
                        } 
                } 

</script> 
 </body>
</html>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天開始打算每周都寫點東西來記錄自己的學習,自己mark一下。 字典是python中最靈活的內置數據結構,字典是無序的集合(字典的順序隨機是為了快速執行鍵查找),python採用最優化的散列演算法來尋找鍵;字典類似於java中的map,但是沒有java中map那麼多類型(HashMap,TreeMap ...
  • python的類(class)和實例(instance) 假設一種鞋子(shoe)有尺碼(size)和顏色(color)兩種屬性,以此為例。 類可以起到模板的作用,因此,可以在創建實例的時候,把一些我們認為必須綁定的屬性強制填寫進去。通過定義一個特殊的__init__方法,在創建實例的時候,就把si ...
  • 對於OpenMP,小喵其實並不是瞭解很多,而且小喵本身也只用到了OpenMP的最簡單的功能。在這裡主要是分享一個自己常用的寫簡單的並行程式的思路。希望能幫助到大家。 這個設計模式的主要特點如下: 1,處理的任務是獨立的; 2,可以在運行中輸出結果,而不是最終才輸出; 3,有限的資源占用; 4,在每次... ...
  • 描述 Description 以下的數字倒直角三角形是由二個數確定的:一個數是行數R,1<=R<=39,另一個是種子數S,1<=S<=9。S放在左上角,照著樣例輸出文件的樣子,寫一個程式,根據輸入的二個數列印出相應的數字倒直角三角形。 輸入格式 Input Format 單獨一行,二個用空格隔開的整 ...
  • ...
  • 1. PHP源碼結構 PHP的內核子系統有兩個,ZE(Zend Engine)和PHP Core.ZE負責將PHP腳本解析成機器碼(也成為token符)後,在進程空間執行這些機器碼;ZE還負責記憶體管理,變數作用域管理和對PHP函數的調度管理。 PHP Core負責和SAPI層的通信;PHP Core ...
  • 首先說明一下,PHP擴展有兩種編譯方式:方式一:在編譯PHP時直接將擴展編譯進去方式二:擴展被編譯成.so文件,在php.ini里配置載入路徑; 以下開始說明創建PHP擴展並編譯的步驟:下載PHP源碼,並解壓,在源碼的根目錄下開始操作,1. 使用ext_skel生成擴展框架,如下: ➜ php-5. ...
  • 碰到個奇葩事啊,一個spring的項目拿到客戶現場部署到resin4中,啟動後各種報無法註入bean,找不到bean的問題.出現大量下圖的錯誤: 除了系統,其他的jdk版本,resin版本,程式包都是在相同測試環境成功部署測試過的,無任何問題.所以想當然的認為可能拿過去的包有問題,馬上本地resin ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...