在网页开发中,常常遇见这种问题,给定两个框,A和B,和几个图片按钮,A中存在几个操作,点击图片按钮,填加至B中,或者从B中移除等,这种效果如何实现,本文加以总结。

几种效果图如下:

原始图:                                                                                                                 添加全部功能图:                               移除全部功能图:

                                                                        

添加选中功能图:                                                      

 

移除选中功能图:

实现思路:

1、首先要做出这种效果图,借助的标签的select标签,select标签设置高度,同时设置该标签的multiple属性---------->multiple="multiple",该属性两个作用,①显示全部的信息②允许多选

2、给各个按钮注册点击事件,

3、添加全部功能

在点击事件中,利用element.children获得第一个select标签中所有元素option,遍历所有的元素option,利用element.appendChild()方法,将遍历到的option添加至第二个select,需要注意的是,element.appendChild()会将待插入的元素从原位置移除,插入到新位置,这样会伴随原select中元素的索引变化,导致功能添加有遗漏,需要注意,代码中已经添加了解决办法,可以每次都获取第一个元素option添加,或者每次在for循环内让i--

4、移除全部功能

原理与3类似,不做赘述

5、添加选中功能

在点击事件中,遍历第一个select中的元素,创建临时数组,如果select元素被选中,则被push()进临时数组中,再遍历临时数组,利用element.appendChild()将元素添加至第二个select中。这样利用数组目的是为了让选中项不至于倒序。

6、移除选中功能

原理与5类似,不做赘述

代码如下:

 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>功能框的移出与添加</title> <!-- 给两个下拉框添加样式 -->
<style type="text/css">
select{
height: 200px;
width: 150px;
}
</style>
</head>
<body>
<!-- 定义所有功能框 -->
<select id="allFuntionBox" multiple="multiple">
<option value ="0">关羽</option>
<option value ="1">张飞</option>
<option value ="2">赵云</option>
<option value ="3">马超</option>
<option value ="4">黄忠</option>
<option value ="5">魏延</option>
<option value ="6">严颜</option>
<option value ="7">关平</option>
<option value ="8">周仓</option>
</select>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <!-- 定义需要功能框 -->
<select id="CheckFuntionBox" multiple="multiple">
</select> <br/><br/> <input type="button" id="btn_addAll" value="添加全部功能" />
<input type="button" id="btn_addChecked" value="添加选中功能" />
<input type="button" id="btn_RemoveAll" value="移除所有功能" />
<input type="button" id="btn_RemoveChecked" value="移除选中功能" /> <!-- 插入JS代码 -->
<script type="text/javascript">
// 准备工作
// 获取两个select标签以及四个按钮
var allFuntionBox=document.getElementById('allFuntionBox');
var CheckFuntionBox=document.getElementById('CheckFuntionBox');
var btn_addAll=document.getElementById('btn_addAll');
var btn_addChecked=document.getElementById('btn_addChecked');
var btn_RemoveAll=document.getElementById('btn_RemoveAll');
var btn_RemoveChecked=document.getElementById('btn_RemoveChecked'); //1.添加全部功能按钮
btn_addAll.onclick=function(){
for(var i=0;i<allFuntionBox.children.length;){
var option=allFuntionBox.children[i];
CheckFuntionBox.appendChild(option);
}
} //2.移除全部功能
btn_RemoveAll.onclick=function(){
for(var i=0;i<CheckFuntionBox.children.length;){
var option=CheckFuntionBox.children[i];
allFuntionBox.appendChild(option);
}
} //3.添加选中功能
btn_addChecked.onclick=function(){
var temp=[];//定义数组,存放选中的项目
for(var i=0;i<allFuntionBox.children.length;i++){
var option=allFuntionBox.children[i];
if(option.selected){
temp.push(option);
option.selected=false;
}
}
for(var i=0;i<temp.length;i++){
CheckFuntionBox.appendChild(temp[i]);
}
} //4.移除选中功能
btn_RemoveChecked.onclick=function(){
var temp=[];
for(var i=0;i<CheckFuntionBox.children.length;i++){
var option=CheckFuntionBox.children[i];
if(option.selected){
temp.push(option);
option.selected=false;
}
}
for(var i=0;i<temp.length;i++){
allFuntionBox.appendChild(temp[i]);
}
}
</script>
</body>
</html>

javascript--select标签的添加删除功能的使用的更多相关文章

  1. NGUI-为Popuplist的下拉选项添加删除功能

    NGUI例子里的popuplist是这样的:,但有时我们希望下拉选项都有删除功能,也就是这样:,一种方法是改popuplist的源码,我想这个实现起来不难,但现在我想说的是用反射来实现此功能,以及其他 ...

  2. jqGrid添加删除功能(不和数据库交互)

    jqGrid添加删除功能(不和数据库交互) 一.背景需求 项目中需要在前端页面动态的添加行,删除行,上下移动行等,同时还不和数据库交互.一直在用jqGrid展示表格的我们,从没有深入的研究过它,当然看 ...

  3. javascript select标签的操作

    用原生的方法对select标签的增删操作 1.选中某一个option,一般采用 option[i].selected  = true 2.添加option首先需要创建一个option的节点,然后插入到 ...

  4. JavaScript DOM方法表格添加删除

    <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title> ...

  5. 多选select实现左右添加删除

    案例:实现效果 1.选择监控城市,车辆列表显示对应城市所有车辆 2.从左边选择车辆  单击  >>   实现右侧显示添加车辆 ,左侧对应移除已选择车辆 3.右侧选中车辆     单击 &l ...

  6. JavaScript在div后添加删除div

    var idd = 'str'; $('.task-done-detail-content-p7').click(function () { var id = this.id; if(idd !== ...

  7. JavaScript 原生控制元素添加删除

    参考: https://blog.csdn.net/leijie0322/article/details/80664554 https://www.cnblogs.com/jpfss/p/910620 ...

  8. javascript——select 标签的使用

    <% String state = (String) request.getAttribute("state"); String day = (String) request ...

  9. 在select标签中添加a标签

    <!--第一个选项不能写连接--> <select id="" onchange="window.location=this.value"&g ...

随机推荐

  1. ASP.NET 中对大文件上传的简单处理

    在 ASP.NET 开发的过程中,文件上传往往使用自带的 FileUpload 控件,可是用过的人都知道,这个控件的局限性十分大,最大的问题就在于上传大文件时让开发者尤为的头疼,而且,上传时无法方便的 ...

  2. Java NIO(二) Channel

    Java NIO的通道类似流,但又有些不同: 既可以从通道中读取数据,又可以写数据到通道.但流的读写通常是单向的. 通道可以异步地读写. 通道中的数据总是要先读到一个Buffer,或者总是要从一个Bu ...

  3. RecycleView + SwipeRefreshLayout 实现下拉刷新和底部自动加载

    前段时间项目里面使用了RecycleView 但是里面的刷新和加载都是框架里面封装好的,直接使用 这几天比较闲就自己来实现以下. 因为SwipeRefreshLayout是一个下拉刷新控件所有直接和R ...

  4. 检查你要加入到gradle的第三方library是否是最新版本

    开发者从博客.github readme  或者 官方文档中找到如何在gradle 文件中加入dependency  的时候,往往版本已经比较老旧了,想要找到最新版,介绍一个利器 http://gra ...

  5. .NET部分知识点整理

    .Net学习 Visual Studio2018 企业版:NJVYC-BMHX2-G77MM-4XJMR-6Q8QF 专业版:KBJFW-NXHK6-W4WJM-CRMQB-G3CDH 开发工具常用V ...

  6. 记录项目代码迁移后,UI测试框架的搭建(配置文件的修改、测试脚本试运行)

    前文:记录一次项目代码迁移过程 上文代码迁移的目的就是为了新增vue脚手架自带的UI测试框架,工具有了,就需要实践运行在项目中了(修改配置文件.编写测试脚本等). 一.单元测试 测试框架 karma ...

  7. Kubernetes Helm入门指南

    什么是Helm?这可不是暗黑破坏神里装备的名称:头盔,而是Kubernetes的一个包管理工具,用来简化Kubernetes应用的部署和管理.我们Helm和Kubernetes的关系,我们可以理解成y ...

  8. python26 re正则表达式

    #coding:utf-8 #/usr/bin/python """ 2018-11-25 dinghanhua re """ import ...

  9. 【[AHOI2012]树屋阶梯】

    卡特兰数! 至于为什么是卡特兰数,就稍微说那么一两句吧 对于一个高度为\(i\)的阶梯,我们可以在左上角填一个高度为\(k\)的阶梯,右下角填一个高度为\(i-1-k\)的阶梯剩下的我们用一个大的长方 ...

  10. Hibernate多表查询连接操作

    SQL多表操作分类; 1.交叉连接:select*from t_customer cross Join t_order; 2.显示内连接: select*from t_customer c inner ...