/**
删除多选select中 的某个值,公共方法
只适用于同级节点下只有一个select的情况
v 此按钮,this
_id,option中的value的name属性
_name,option中的text的name属性
***如果每次添加不清空options,而是在原有基础添加
pr_id:备用value,需要保留select中之前的数据时填写
pr_name:备用 name,需要保留select中之前的数据时填写
*/
function deletedOne(v,_id,_name,pr_id,pr_name){
var id="input:hidden[name="+_id+"]";
var name="input:hidden[name="+_name+"]";
var parent=$(v).parent();
var sele=parent.find("select")[0];
var options=sele.options;
if(options){
for(var i=0;i<options.length;i++){
if(options[i].selected){
options.remove(i);
}
}
var idstr="";
var namestr="";
for(var i=0;i<options.length;i++){
if(!options[i].selected){
if(idstr==""){
idstr=options[i].value;
namestr=options[i].text;
}else{
idstr=idstr+","+options[i].value;
namestr=namestr+","+options[i].text;
}
}
}
var id_node=parent.find(id)[0];
var name_node=parent.find(name)[0];
$(id_node).val(idstr);
$(name_node).val(namestr);
if(pr_id && pr_name){
var _id_node=parent.find("input:hidden[name="+pr_id+"]")[0];
var _name_node=parent.find("input:hidden[name="+pr_name+"]")[0];
$(_id_node).val(idstr);
$(_name_node).val(namestr);
}
}
}
/**
公共的多选框显示方法
v:按钮
_id:value的name属性
_name:text的name属性
****如果每次添加不清空options,而是在原有基础添加
_pr_id:备用字段value,需要保留select中之前的数据时填写
_pr_name:备用字段name,需要保留select中之前的数据时填写
*/
function showSelect(v,_id,_name,_pr_id,_pr_name){
var parent=$(v).parent();
//获取同级下的节点
var name_node=parent.find("input:hidden[name="+_name+"]")[0];
var id_node=parent.find("input:hidden[name="+_id+"]")[0];
var idstr=$(id_node).val();
var namestr=$(name_node).val();
var ids=idstr.split(",");
var names=namestr.split(",");
//两个字段不为空时进行拼接操作,并把当前数据保留至备用位置
if(_pr_id && _pr_name){
var pr_id_node=parent.find("input:hidden[name="+_pr_id+"]")[0];
var pr_name_node=parent.find("input:hidden[name="+_pr_name+"]")[0];
var pr_idstr=$(pr_id_node).val();
var pr_namestr=$(pr_name_node).val();
if(pr_idstr){
for(var i=0;i<ids.length;i++){
var index=(pr_idstr+",").indexOf(ids[i]+",");
if(index==-1){
pr_idstr=pr_idstr+","+ids[i];
pr_namestr=pr_namestr+","+names[i];
}
}
$(pr_id_node).val(pr_idstr);
$(pr_name_node).val(pr_namestr);
$(id_node).val(pr_idstr);
$(name_node).val(pr_namestr);
}else{
$(pr_id_node).val(idstr);
$(pr_name_node).val(namestr);
}
}
//把值显示出在多选框
var sele=parent.find("select")[0];
$(sele).empty();
var result_str=$(id_node).val();
if(result_str){
var result_ids=result_str.split(",");
var result_name=$(name_node).val().split(",");
for(var i=0;i<result_ids.length;i++){
var opt=new Option(result_name[i],result_ids[i]);
opt.title=result_name[i];
sele.add(opt);
}
}
}

多行select中的数据展示和单个删除的更多相关文章

  1. C#-WinForm-ListView-表格式展示数据、如何将数据库中的数据展示到ListView中、如何对选中的项进行修改

    在展示数据库中不知道数量的数据时怎么展示最好呢?--表格 ListView - 表格形式展示数据 ListView 常用属性 HeaderStyle - "详细信息"视图中列标头的 ...

  2. jstl-将List中的数据展示到表格中

    功能: 使用jstl将List中的数据动态展示到Jsp表格中,并实现隔行换色功能. 效果图: Jsp代码: <%@ page import="java.util.ArrayList&q ...

  3. delete表1条件是另一个表中的数据,多表连接删除(转)

    DELETE删除多表数据,怎样才能同时删除多个关联表的数据呢?这里做了深入的解释: 1. delete from t1 where 条件 2.delete t1 from t1 where 条件 3. ...

  4. MVC设计模式((javaWEB)在数据库连接池下,实现对数据库中的数据增删改查操作)

    设计功能的实现: ----没有业务层,直接由Servlet调用DAO,所以也没有事务操作,所以从DAO中直接获取connection对象 ----采用MVC设计模式 ----采用到的技术 .MVC设计 ...

  5. 大数据技术之_25_手机APP信息统计系统项目_01_APP 数据生成模块 + 数据收集模块 + 数据处理模块框架搭建 + 业务需求处理 + 数据展示模块 +项目总结 + 问题总结

    一 项目概述1.1 角色1.2 业务术语1.3 项目效果展示二 项目需求三 项目概要3.1 项目技术架构3.2 项目目录结构3.3 项目技术选型3.4 项目整体集群规划3.5 创建项目工程四 APP ...

  6. html中的数据岛:利用DSO和javascript在html中动态加载和浏览xml数据

    1.DSO也叫做数据源对象,IE 4.0引入了DSO,在IE 5.0对DSO技术进行很大的扩展.以往如果数据是通过SQL语言对数据库进行查询得到的结果,那么就把它们存放在ADO(ActiveX Dat ...

  7. EF Core中如何通过实体集合属性删除从表的数据

    假设在数据库中有两个表:Person表和Book表,Person和Book是一对多关系 Person表数据: Book表数据: 可以看到数据库Book表中所有的数据都属于Person表中"F ...

  8. php实例根据ID删除mysql表中的数据

    在动态网站开发中,我们经常要根据ID删除表中的数据,例如用户删除帖子,就需要根据ID删除帖子.本文章向大家介绍php根据ID删除表中数据的实例,需要的朋友可以参考一下本文章的实例. php实例根据ID ...

  9. 默认情况下,不使用of子句表示在select所有的数据表中加锁(转)

    Select …forupdate语句是我们经常使用手工加锁语句.通常情况下,select语句是不会对数据加锁,妨碍影响其他的DML和DDL操作.同时,在多版本一致读机制的支持下,select语句也不 ...

随机推荐

  1. JAVA 中的IO流

    Java中的IO流是用来处理设备与设备之前的数据传输,在java中以流的形式传输.流分为两类:字节流和字符流. 字节流:InputStream,OutPutSteam.(计算机内的数据都是以字节存储的 ...

  2. 架构之路:nginx与IIS服务器搭建集群实现负载均衡

    http://blog.csdn.net/zhanghan18333611647/article/details/50811980

  3. RTX二次开发::检索 COM 类工厂中 CLSID 为 {79210E58-99EB-45D0-8890-763EFEAA143F} 的组件失败,

    解决方法: 1.Interop.RTXSAPILib.dll这个是32位的 将IIS 应用程序池 启用32位应用程序 设置为true就可以了, 2.把编译好的程序选择X86平台运行,就好了 程序员的基 ...

  4. [SoapUI] Global Scripts For Reusability

  5. RCC—使用 HSE/HIS 配置时钟

    RCC :reset clock control  复位和时钟控制器:特别是要着重理解时钟树,理解了时钟树,F429 的一切时钟的来龙去脉都会了如指掌. STM32F4系列有5个时钟源: LSIRC( ...

  6. eclipse netbeans 代码模板

    eclipse  代码模板  插入slf4j ${:import(org.slf4j.Logger,org.slf4j.LoggerFactory)} private static final Log ...

  7. springboot+mongonDB

    一.mongonDB基本介绍 什么是MongoDB ? MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. Mon ...

  8. Error creating bean with name 'as' defined in class path resource

    (1)一个是setter方法的名字和配置文件对应名字有问题 (2)导入的包不对,搭建环境出错.

  9. UVa 12099 The Bookcase (DP)

    题意:有 n 本书,每本书有一个高度和宽度,然后让你制作一个3层的书架,可以放下所有的书,并且要高*宽尽量小. 析:先把所有的书按高度进行排序,然后dp[i][j][k] 表示 前 i 本书,第二 层 ...

  10. C# 生成dll文件 并导入使用

    首先 在unity创建一个脚本 并编写内容,其中需要调用的方法.变量要公有化(也可以直接新建cs文件用编译器打开编译,但要先导入UnityEngine.dll). 然后,复制脚本关闭unity,在外界 ...