JavaScript学习记录总结(九)——移动添加效果
<!DOCTYPE html>
<html>
<head>
<title>moveOption.html</title>
<meta name="keywords" content="keyword1,keyword2,keyword3">
<meta name="description" content="this is my page">
<meta name="content-type" content="text/html; charset=UTF-8">
<!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
<script type="text/javascript">
//声明全局变量
var loptionDom; //左边的select对应的Dom对象
var roptionDom; //右边的select对应的DOM对象
//窗体加载完毕 获取dom对象
window.onload = function() {
//获取左边的select对应的Dom对象
loptionDom = document.getElementById("loption");
//获取右边的select对应的DOM对象
roptionDom = document.getElementById("roption");
};
//向右移动
function moveRight(value) {
//获取左边select所有的option集合对象
var options = loptionDom.options;
//判断是否是单个移动
if (value == 1) {
//记住要移动的option对象
var remberoptionDom = null;
//记住要移动的option的数量
var count = 0;
//遍历options集合对象
for (var i = 0; i < options.length; i++) {
//获取option对象
var optionDom = options[i];
//判断是否是选中的option对象selected="selected"
if (optionDom.selected) {
//赋值
remberoptionDom = optionDom;
//数量递增
count++;
}
}
//判断数量是否是1 如果是1代表移动一个
if (count == 1) {
//添加到了右边
roptionDom.appendChild(remberoptionDom);
//左边要移除
loptionDom.removeChild(remberoptionDom);
} else if (count == 0) {
alert("请选择要移动的数据");
} else {
alert("请选择==>移动");
}
} else if (value == 0) {
//遍历操作 为啥 一定要写成 i=options.length-1 ; i>=0;i--
for (var i = options.length - 1; i >= 0; i--) {
//获取option对象
var optionDom = options[i]; //options[0] //8
//判断是否被选中
if (optionDom.selected) {
//左边要移除
loptionDom.removeChild(optionDom);
//添加到了右边
roptionDom.appendChild(optionDom);
}
}
}
}
//向左移动
function moveLeft(value) {
if (value == 1) {
} else if (value == 0) {
}
}
</script>
</head>
<body>
<!-- 左右移动的整个代码 -->
<div style="width: 400px; height: 280px;margin: 0px auto;">
<!-- 左边的代码 -->
<div style="width: 100px; float:left;">
<select multiple="multiple" style="height: 200px; width: 80px;"
id="loption">
<option>选项1</option>
<option>选项2</option>
<option>选项3</option>
<option>选项4</option>
<option>选项5</option>
<option>选项6</option>
<option>选项7</option>
<option>选项8</option>
<option>选项9</option>
</select>
</div>
<!-- 中间代码 -->
<div style="width: 100px;float: left;margin-right: 30px;">
<ul style="list-style: none;">
<li><input type="button" value="-->"
style="width: 40px; margin-bottom: 15px;" onclick="moveRight(1)" />
<input type="button" value="==>"
style="width: 40px;margin-bottom: 15px;" onclick="moveRight(0)" />
<input type="button" value="<--"
style="width: 40px;margin-bottom: 15px;" onclick="moveLeft(1)" /> <input
type="button" value="<==" style="width: 40px;margin-bottom: 15px;"
onclick="moveLeft(0)" /></li>
</ul>
</div>
<!-- 右边代码 -->
<div style="width: 100px; float: left; ">
<select multiple="multiple" style="height: 200px; width: 80px;"
id="roption"></select>
</div>
</div>
</body>
</html>
效果:
JavaScript学习记录总结(九)——移动添加效果的更多相关文章
- JavaScript学习记录四
title: JavaScript学习记录四 toc: true date: 2018-09-16 20:31:22 --<JavaScript高级程序设计(第2版)>学习笔记 要多查阅M ...
- Lua和C++交互 学习记录之九:在Lua中以面向对象的方式使用C++注册的类
主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3 参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 在 ...
- JavaScript学习记录三
title: JavaScript学习记录三 toc: true date: 2018-09-14 23:51:22 --<JavaScript高级程序设计(第2版)>学习笔记 要多查阅M ...
- JavaScript学习记录二
title: JavaScript学习记录二 toc: true date: 2018-09-13 10:14:53 --<JavaScript高级程序设计(第2版)>学习笔记 要多查阅M ...
- JavaScript学习记录一
title: JavaScript学习记录一 toc: true date: 2018-09-11 18:26:52 --<JavaScript高级程序设计(第2版)>学习笔记 要多查阅M ...
- ElasticSearch 学习记录之ES查询添加排序字段和使用missing或existing字段查询
ES添加排序 在默认的情况下,ES 是根据文档的得分score来进行文档额排序的.但是自己可以根据自己的针对一些字段进行排序.就像下面的查询脚本一样.下面的这个查询是根据productid这个值进行排 ...
- Javascript学习记录——原生JS实现旋转木马特效
昨天学习到了JS特效部分,然后老师讲了旋转木马特效的实现,如上图.不过只是讲了通过点击箭头实现图片的切换,对于点击图片本身以及二者联动却是没有讲解. 本着一颗追求完美的心,今天花费了一个中午终于将整个 ...
- JavaScript学习记录总结(七)——dom对象应用之用户简单管理
<!DOCTYPE html><html><head><title>users.html</title> <meta name=&qu ...
- javascript 学习总结(九)面向对象编程
1.面向对象的工厂方法 function createPerson(name, age, job){ var o = new Object(); o.name = name; o.age = age; ...
随机推荐
- NOIP2013 提高组day2 3 华容道 BFS
描述 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面,华容道是否根本就无法完成,如果能完成,最少需要多少时间. 小 B 玩的华容道与经典的 ...
- Hibernate中的多对多映射
1.需求 项目与开发员工 一个项目,有多个开发人员 一个开发人员,参与多个项目 [多对多] 2.实体bean设计 Project: public class Project { private int ...
- Terminating app due to uncaught
1>Images.xcassets: A 60x60@2x app icon is required for iPhone apps targeting iOS 7.0 and later 图片 ...
- 蓝桥杯 algo——6 安慰奶牛 (最小生成树)
问题描述 Farmer John变得非常懒,他不想再继续维护供奶牛之间供通行的道路.道路被用来连接N个牧场,牧场被连续地编号为1到N.每一个牧场都是一个奶牛的家.FJ计 划除去P条道路中尽可能多的道路 ...
- C/C++中函数参数传递详解(一)
*在定义时使用代表指针类型,其他情况代表取内容.&在定义时使用代表引用(别名),在其他情况代表取地址 在编写个人函数的时候,你将会受到C++中的一条基本的原则的限制:在默认的情况下,变量只能以 ...
- 黑客界大拿tombkeeper文章:怎么学好技术成为技术大拿(题目我自拟的)
这两天论坛上又有人开始抱怨世风日下,大家都现实了,都不开放了,不交流了.对这种“月经贴”,我基本上已经习惯了,不过因为吃了粉皮炖鸡,心情比较好,于是就说了两句. 三四年前,当时我对人性的看法还不像现在 ...
- 标签工作区(navtab)
B-JUI使用标签可以加载其他页面的数据 B-JUI框架的整个工作区部分就是一个navtab组件,本页面位于"#bjui-container"容器内,固定的html结构如下: &l ...
- iframe和form表单的target应用简单例子
iframe和form表单的target属性 Problem: 刷新主页面中的其中一个iframe,其他内容不变 Solution: main.jsp <body onload=" ...
- 使用 VisualVM 进行性能分析及调优
VisualVM 是一款免费的性能分析工具.它通过 jvmstat.JMX.SA(Serviceability Agent)以及 Attach API 等多种方式从程序运行时获得实时数据,从而进行动态 ...
- eclipse中导入一个android工程有The import android cannot be resolved错误怎么办
解决方法: 右键工程→Bulid Path→Configure Build Path... 选择Android,如图,在Project Build Target里面勾选相应的SDK即可 右键工程,pr ...