最简单的可取消多选效果(以从水果篮中挑选水果为例)【jsDEMO】
【功能说明】
最简单的可取消多选效果(以从水果篮中挑选水果为例)
【html代码说明】
<div class="box" id="box">
<input class="out" placeholder = "请挑选我要的水果" disabled>
<button class="btn">合上我的水果篮子</button><br>
<ul class="list">
<li class="in red">苹果</li>
<li class="in purple">葡萄</li>
<li class="in yellow">香蕉</li>
<li class="in green">青梅</li>
<li class="in orange">桔子</li>
</ul>
</div>
【css重点代码说明】
//设置展示框中乳白色文字效果
.out{
width: 300px;
height:30px;
line-height: 50px;
padding: 10px;
text-align: center;
border: 1px solid #ccc;
border-radius: 5px;
font-size: 20px;
color: #f1ebe5;
text-shadow: 0 8px 9px #c4b59d, 0px -2px 1px #fff;
font-weight: bold;
background: linear-gradient(to bottom, #ece4d9 0%,#e9dfd1 100%);
vertical-align: middle;
}
//水果篮显示效果
.list,.list_hid{
height: 50px;
line-height: 50px;
margin-top: 20px;
overflow: hidden;
text-align: center;
background-color: #ccc;
border-radius: 10px;
transition: 500ms height;
}
//水果篮隐藏效果
.list_hid{
height: 0;
}
【js代码说明】
//获取整个盒子
var oBox = document.getElementById('box');
//获取按钮
var oBtn = oBox.getElementsByTagName('button')[0];
//获取展示框
var oOut = oBox.getElementsByTagName('input')[0];
//获取水果篮子
var oList = oBox.getElementsByTagName('ul')[0];
//获取水果篮子里面的所有水果
var aIn = oList.getElementsByTagName('li'); //给按钮绑定事件
oBtn.onclick = function(){
//若list的className为list,说明此时水果篮子处于打开状态
if(oList.className == 'list'){
//更改其className为list_hid,关闭水果篮子
oList.className = 'list_hid';
//设置文字显示为打开我的水果篮子
this.innerHTML = '打开我的水果篮子';
//此时水果篮子处于关闭状态
}else{
//更改其className为list,打开水果篮子
oList.className = 'list';
//设置文字显示为合上我的水果篮子
this.innerHTML = '合上我的水果篮子';
}
} for(var i = 0; i < aIn.length; i++){
//给每个水果添加标记,默认为false,表示未被选中
aIn[i].mark = false;
//给每个水果添加事件
aIn[i].onclick = function(){
//当水果选中时,取消选中;当水果未选中时,将其选中
this.mark = !this.mark;
//若该水果选中,则文字颜色变为亮灰色
if(this.mark){
this.style.color = '#ccc';
//若未选中,则文字颜色为黑色
}else{
this.style.color = 'black';
}
//运行展示框函数
fnOut();
}
} //设置展示框函数
function fnOut(){
//设置临时字符串,来存储展示框要显示的值
var str = '';
for(var i = 0; i < aIn.length; i++){
//当该水果被选中时
if(aIn[i].mark){
//将其innerHTML添加到临时字符串中
str += ',' + aIn[i].innerHTML;
}
}
//再将最开始第一个水果前的逗号去掉
oOut.value = str.slice(1);
};
【效果展示】
最简单的可取消多选效果(以从水果篮中挑选水果为例)【jsDEMO】的更多相关文章
- 使用AngularJS实现简单:全选和取消全选功能
这里用到AngularJS四大特性之二----双向数据绑定 注意:没写一行DOM代码!这就是ng的优点,bootstrap.css为了布局,JS代码也只是简单创建ng模块和ng控制器 效果: < ...
- jQuery实现全选效果【转】
这是一段用jquery实现全选的代码,主要思路如下: 1.所有的复选框都有单击事件,所有效果都是在单击事件下实现的 2.全选复选框所实现的功能与其他复选选项实现的功能不同,所有在单击事件内做一个判断, ...
- avalon全选效果分析讲解
全选功能就是 1.点击全选控制循环元素是否选中.(点击全选,下面的所有元素选中,再次点击 所有元素取消选中.) 2.点击循环元素控制全选.(如果当前元素是未选中状态则全选不选中,如果当前元素是选中状态 ...
- DataGridView取消默认选中行
DataGridView在添加数据后会默认选中第 一个单元格或者第一行,我就想取消它的默认选中行.在DataGridView绑定数据之后加上了ClearSelection().这样一来,不论是启动窗体 ...
- jquery checkbox勾选取消勾选的诡异问题
jquery checkbox勾选/取消勾选的诡异问题jquery checkbox勾选/取消勾选的诡异问题 <form> 你爱好的运动是?<input type=&q ...
- jQuery--checkbox全选/取消全选
用JavaScript使页面上的一组checkbox全选/取消全选,逻辑很简单,实现代码也没有太难的语法.但使用jQuery实现则更简单,代码也很简洁,精辟! jQuery版本:1.3.2 <h ...
- vue实现全选效果
vue实现全选效果 接触vue快半年了,记得刚用vue做项目的时候遇到一个全选功能,当时到处百度也没有找到怎么实现,最后还是用了jquery进行dom操作实现的. 今天没事就顺手写了一个,感觉很简单, ...
- AngularJS--购物车全选/取消全选功能实现
刚学习angularJS,于是练习写了一个类似于购物车的全选/取消全选的功能,主要实现的功能有: 1.勾选全选checkbox,列表数据全部被勾选,取消同理,用ng-model实现双向绑定: 2.选中 ...
- react实现全选、取消全选和个别选择
react里面实现全选和取消全选,个别选择等操作,效果如下 代码: import React, {Component} from 'react' export default class Demo e ...
随机推荐
- Java反射机制调用private类型的构造方法
单例类: package singleton; public class SingletonTest { // 私有构造方法 private SingletonTest(){ System.out.p ...
- PADSPCB权威指南-第一章 PADS软件系统(部分)(原创)
PADSPCB权威指南-第一章(部分)豆丁地址:http://www.docin.com/p-707128286.html
- #include <stdarg.h>
名称描述相容 // 作用描述 va_start使va_list指向起始的参数 va_arg检索参数C89 va_end释放va_list va_copy拷贝va_list的内容 实例解析: #inc ...
- Windows Server 2003搭建邮件服务器
Windows Server 2003搭建邮件服务器 由于Windows Server 2003默认是没有安装我们搭建邮件服务器所需要的POP3和SMTP服务的,因此需要我们自己来安装.方法如下: 1 ...
- cocos2d-x 2.2.2 android平台移植
1.完成以上工具的下载安装--cocos2d-x 2.2.2 --eclipse+adt+sdk --ndk 2.创建cocos2d-x工程 在"cocos2d-x-2.2.2\tools\ ...
- SQL入门经典(八) 之存储过程
存储过程(stored procedure)有时候称为sproc,它是真正的脚本-或者更准确的说,他是批处理(batch)-它存储于数据库中,而不是淡出的文件中.无论如何,这个比较并不是很确定.存储过 ...
- FtpDataStream中的隐藏问题
最近在使用FtpWebResponse.GetResponseStream方法时遇上个问题——Stream在未关闭之前就报出了ObjectDisposedException.刚开始十分困惑,因为一直用 ...
- 在Ubuntu中安装Python3
首先,通过命令行安装Python3.2,只需要在终端中通过命令行安装即可: sudo apt-get install python3 一路yes. 因为Ubuntu很多底层采用的是Python2. ...
- 用StackExchange.Redis客户端连接阿里云Redis服务遇到的问题
阿里云推荐的Redis服务.NET客户端是ServiceStack.Redis,但ServiceStack.Redis不支持异步,不支持.NET Core,于是尝试使用StackExchange.Re ...
- 设计模式之美:State(状态)
索引 意图 结构 参与者 适用性 效果 相关模式 实现 实现方式(一):由 ConcreteState 指定它的后继 State. 意图 允许一个对象在其内部状态改变时改变它的行为.对象看起来似乎修改 ...