多行select中的数据展示和单个删除
/**
删除多选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中的数据展示和单个删除的更多相关文章
- C#-WinForm-ListView-表格式展示数据、如何将数据库中的数据展示到ListView中、如何对选中的项进行修改
在展示数据库中不知道数量的数据时怎么展示最好呢?--表格 ListView - 表格形式展示数据 ListView 常用属性 HeaderStyle - "详细信息"视图中列标头的 ...
- jstl-将List中的数据展示到表格中
功能: 使用jstl将List中的数据动态展示到Jsp表格中,并实现隔行换色功能. 效果图: Jsp代码: <%@ page import="java.util.ArrayList&q ...
- delete表1条件是另一个表中的数据,多表连接删除(转)
DELETE删除多表数据,怎样才能同时删除多个关联表的数据呢?这里做了深入的解释: 1. delete from t1 where 条件 2.delete t1 from t1 where 条件 3. ...
- MVC设计模式((javaWEB)在数据库连接池下,实现对数据库中的数据增删改查操作)
设计功能的实现: ----没有业务层,直接由Servlet调用DAO,所以也没有事务操作,所以从DAO中直接获取connection对象 ----采用MVC设计模式 ----采用到的技术 .MVC设计 ...
- 大数据技术之_25_手机APP信息统计系统项目_01_APP 数据生成模块 + 数据收集模块 + 数据处理模块框架搭建 + 业务需求处理 + 数据展示模块 +项目总结 + 问题总结
一 项目概述1.1 角色1.2 业务术语1.3 项目效果展示二 项目需求三 项目概要3.1 项目技术架构3.2 项目目录结构3.3 项目技术选型3.4 项目整体集群规划3.5 创建项目工程四 APP ...
- html中的数据岛:利用DSO和javascript在html中动态加载和浏览xml数据
1.DSO也叫做数据源对象,IE 4.0引入了DSO,在IE 5.0对DSO技术进行很大的扩展.以往如果数据是通过SQL语言对数据库进行查询得到的结果,那么就把它们存放在ADO(ActiveX Dat ...
- EF Core中如何通过实体集合属性删除从表的数据
假设在数据库中有两个表:Person表和Book表,Person和Book是一对多关系 Person表数据: Book表数据: 可以看到数据库Book表中所有的数据都属于Person表中"F ...
- php实例根据ID删除mysql表中的数据
在动态网站开发中,我们经常要根据ID删除表中的数据,例如用户删除帖子,就需要根据ID删除帖子.本文章向大家介绍php根据ID删除表中数据的实例,需要的朋友可以参考一下本文章的实例. php实例根据ID ...
- 默认情况下,不使用of子句表示在select所有的数据表中加锁(转)
Select …forupdate语句是我们经常使用手工加锁语句.通常情况下,select语句是不会对数据加锁,妨碍影响其他的DML和DDL操作.同时,在多版本一致读机制的支持下,select语句也不 ...
随机推荐
- len=in.read(b,0,len)和len=in.read(b)的区别
byte[] byte = new byte[1024]; int len =0 ; while((len=in.read(b))!=-1){ out.write(b,0,len); } read函数 ...
- http和socket之长连接和短连接区别(转)
TCP/IP TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层. 在网络层有IP协议.ICMP协议.ARP协议.RARP协议和BOOTP协议. 在传输层中有TCP协议与UDP协议. 在应 ...
- eclipse+hbase开发环境部署
一.前言 1. 前提 因为hbase的运行模式是伪分布式,需要用到hdfs,所以在此之前,我已经完成了hadoop-eclipse的开发环境搭建,详细看另一篇文章:hadoop开发环境部署——通过ec ...
- [C++] 2D Array's memory allocation
2D Array's memory allocation
- sed命令n,N,d,D,p,P,h,H,g,G,x解析2
摘自: https://blog.csdn.net/xiexingshishu/article/details/50514132 sed命令n,N,d,D,p,P,h,H,g,G,x解析 2016年0 ...
- Django学习笔记:为Model添加Action
|- Django版本:1.8 |- Python版本:3.4 models.py 1 class Story(models.Model): #编辑Story状态 STATUS_CHOICES = ( ...
- Web测试-day
昨天太忙忘了写博客,今天补上: 这两天完成的工作: 我们组选定了博客园和CSDN作为对比,进行Web测试. 胡俊辉--找到了10个网页的bug,并完成了bug记录文档,并且对CSDN和博客园进行功能分 ...
- [GO]结构体成员的使用:普通变量
package main import "fmt" func main() { type student struct { id int name string sex byte ...
- 【转载】Redis的Java客户端Jedis的八种调用方式(事务、管道、分布式…)介绍
转载地址:http://blog.csdn.net/truong/article/details/46711045 关键字:Redis的Java客户端Jedis的八种调用方式(事务.管道.分布式…)介 ...
- CodeForces 342A Xenia and Divisors (水题)
题意:给定 n 个数(小于等于7),让你把它分成 m 组,每组有三个数,且满足,a < b < c,并且 a 能整除 b,b 能整除 c. 析:对于这个题,因为题目说了是不大于7的,那么一 ...