optiontransferselect例子

Struts2 OptionTransferSelect标签 动态赋值:

1、html片面:

<td class="td2">
    <s:optiontransferselect
    id="sysWard"
    doubleId="userWard"
    name="userDept"
    list="deptMap"
    listKey="key"
    listValue="value"
    multiple="true"
    headerKey="cnKey"
    leftTitle="选择部门向右添加"
    doubleList="deptNameMap"
    doubleListKey="key"
    doubleListValue="value"
    doubleName="userBean.placeDept"
    doubleHeaderKey="cnKey"
    rightTitle="科护士长管理科室"
    doubleMultiple="true"
    allowSelectAll="false"
    allowUpDownOnLeft="false"
    allowUpDownOnRight="false"
    addToLeftLabel="<<--向左"
    addToRightLabel="向右-->>"
    addAllToRightLabel="全选向右"
    addAllToLeftLabel="全选向左"
    cssClass="option"
    doubleCssClass="option"
    />
</td>

2、异步动态赋值:

// 选择科护士长 事件
$("#select_userBean").change(function(){
    $("#user_job_number").val($(this).val());

    $.ajax({
        type:"post",
        url:"ManagerDept_setSysDept_null_null",
        data:{"userJobNumber":$("#user_job_number").val()},
        async: false,
        dataType:"json",
        success:function(msg){
        var obj = eval(msg);
        $("#sysWard option").remove();//将select中的信息清空
        $.each(obj, function(key,value){
            $("#sysWard").append("<option value="+key+">" + value + "</option>");
        });
        }
    });
    $.ajax({
        type:"post",
        url:"ManagerDept_setUserDept_null_null",
        data:{"userJobNumber":$("#user_job_number").val()},
        async: false,
        dataType:"json",
        success:function(msg){
        var obj = eval(msg);
        $("#userWard option").remove();//将select中的信息清空
        $.each(obj, function(key,value){
            $("#userWard").append("<option value="+key+">" + value + "</option>");
        }); }
                    });
                });
// 修改按钮 事件
$("#btn_updateManageDept").click(function(){
    var depts = "";
    $("#userWard").find("option").each(function(i){
    depts += $(this).val()+",";
    });
    depts = depts.substr(0,depts.length-1);
    $.ajax({
    type:"post",
    url:"ManagerDept_updateManagerDept_null_null",
    data:{"depts":depts,"userJobNumber":$("#user_job_number").val()},
    async: false,
    dataType:"json",
    success:function(msg){
        if(msg == "1"){
        alert("更新成功!");
        }else{
        alert("更新失败!");
        }
    }
    });
});

********************************************************************************************************

关键点1:动态赋值:

$("#sysWard option").remove();//将select中的信息清空
$.each(obj, function(key,value){
    $("#sysWard").append("<option value="+key+">" + value + "</option>");
});

其实,就是获取分别获取左右的 select 选择框,并分别动态添加 <option>标签。

关键点2:jquery遍历Map:

$.each(obj, function(key,value){
    $("#userWard").append("<option value="+key+">" + value + "</option>");
});

如上代码,obj 对象时后台传递的Map对象,jquery 遍历 Map,不能像遍历Array一样,在function中传递i,作为数组索引。而是在function中传递两个参数 key 和 value,分别代表Map对象的key和value值。

关键点3:获取右边select的值:

var depts = "";
$("#userWard").find("option").each(function(i){
    depts += $(this).val()+",";
});
depts = depts.substr(0,depts.length-1);

获取右边 select 的值,不能知道获取。有两种方法,方法一:可以把右边框中的值设置全部选中,即将selected 属性设置为true;方法二:就如上文的获取select 选择框的值。

时间: 2024-08-13 09:47:15

optiontransferselect例子的相关文章

Android小例子:使用反射机制来读取图片制作一个图片浏览器

效果图: 工程文件夹: 该例子可供于新手参考练习,如果有哪里不对的地方,望指正>-< <黑幕下的人> java代码(MainActivity.java): package com.example.imageswitchtest; import java.lang.reflect.Field; import android.app.Activity; import android.os.Bundle; import android.util.Log; import android.v

JSON 简单例子

代码: json [ { "title" : "a", "num" : 1 }, { "title" : "b", "num" : 1 }, { "title" : "c", "num" : 1 }] 例子1 js var box=[ { title:'a', num:1, height:177, }, { title:'b',

最简单的基于FFmpeg的AVDevice例子(读取摄像头)【转】

转自:http://blog.csdn.net/leixiaohua1020/article/details/39702113 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] libavdevice使用 注意事项 代码 结果 下载 =====================================================最简单的基于FFmpeg的AVDevice例子文章列表: 最简单的基于FFmpeg的AVDevice例子(读取摄像头) 最简单的基于FFm

Clustering by Passing Messages Between Data Points(Brendan J.Frey* and Delbert Dueck)例子

例1,数据点聚类:AP应用到25个二维数据中,使用负平法误差作为相似度  聚类数目不用预先指定 AP的一个优点是聚类数目不用预先指定,而是在消息传递方法中慢慢浮现,取决于输入参考度(preference),这种自动模型的选择,基于先验指定每一个数据点有多合适作为exemplar. 下图表示输入常量参考度对聚类数目的影响,这种关系近乎同样于在精确最小平方误差中的关系. 例2,人脸识别:使用优化标准为均方差,识别900张灰度图像   AP一致的能够实现更低的误差,在时间上花费要少于两个数量级. AP

Python之路42-socket介绍及简单例子

socket对数据的底层收.发做了封装 实现通信要通过IP+port 一个socket服务端和客户端实现的伪代码 # 发送端 # import socket # socket.TCP/IP # connect(a.ip,a.port) # socket.send("hello") # socket.recv() # socket.close() # 接收端 # import socket # socket.TCP/IP # listen(0.0.0.0,6969) # waiting(

c语言一个例子对比php学习随记

今天开始学写一些简单的C例子,发现很多和PHP不一样的地方,做个笔记. #include <stdio.h> int main(void) { int a,b; printf("请输入整数a"); //这里是用双引号,不能用单引号,PHP类似的地方可以用单引号,这里需注意 scanf("%d",&a); //获取用户输入值存入a printf("请输入整数b"); scanf("%d",&b);//

判断当前进程是否以管理员权限运行(AllocateAndInitializeSid后,用CheckTokenMembership与AdministratorsGroup进行比较,和Delphi的那个例子还有点不一样)

在Win7下(Vista以上的...)有时某些操作就是会让人郁闷 开启了UAC的话,得以管理员权限运行才不会出现Access is denied... 但是,程序又不是非得什么时候都用那破管理员权限的 总不能在manifest里加权限,然后用户运行时老弹确认吧? 当然啦,可以将需要管理员权限的部分写到另一个小程序,需要时调用它就行了 不过还是不爽,如果是一个小小的程序还要再加另一个小小小程序的话 那好,干脆判断是不是Win7...开启了UAC没有之类 开启的话再判断下是不是以管理员权限运行,不是

Web前端入门学习(6)——浮动例子之鉴赏

浮动例子之鉴赏 在浮动原理及清除浮动一文中(http://cherry360.blog.51cto.com/12176744/1864258),简单介绍了浮动的相关基础知识,为了巩固知识点,本篇结合代码展示关于浮动的几个常见例子. 例1:九格子 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>九格子</titl

【Bootstrap Demo】入门例子创建

本文简单介绍下如何来使用 Bootstrap,通过引入 Bootstrap,来实现一个最基本的入门例子. 在前一篇博文[Bootstrap]1.初识Bootstrap 基础之上,我们完全可以更加方便快捷的创建一个的简单例子.这个例子只有基本的东西:引入了预编译版的 CSS 和 JavaScript 文件,页面只包含了一个 container 元素. 在Bootstrap的官方网站的下载页面 http://getbootstrap.com/getting-started/#download ,也有