- 浏览: 6349173 次
- 性别:
- 来自: 一片神奇的土地
文章分类
- 全部博客 (745)
- JQuery (25)
- JS (33)
- 数据库 (59)
- Java基础 (56)
- JSON (8)
- XML (8)
- ireport (7)
- 设计模式 (10)
- 心情 (14)
- freemarker (1)
- 问题 (15)
- powerdesigner (2)
- CSS (15)
- DWR (4)
- tomcat (16)
- Hibernate (12)
- Oracle (7)
- Struts (7)
- Spring (34)
- JSP (23)
- 需学习 (64)
- 工具类库 (63)
- Maven (14)
- 笔试题 (34)
- 源码学习 (31)
- 多线程 (39)
- Android (32)
- 缓存 (20)
- SpringMVC (14)
- jQueryEasyUi (12)
- webservice-RPC (13)
- ant (1)
- ASP.NET (10)
- 正则表达式 (3)
- Linux (15)
- JBoss (1)
- EJB (3)
- UML (2)
- JMS (3)
- Flex (8)
- JSTL (2)
- 批处理 (5)
- JVM (16)
- 【工具】 (16)
- 数据结构 (29)
- HTTP/TCP/Socket (18)
- 微信 (1)
- tomcat源码学习 (15)
- Python (30)
- 主机 (2)
- 设计与架构 (19)
- thrift-RPC (2)
- nginx (6)
- 微信小程序 (0)
- 分布式+集群 (12)
- IO (1)
- 消息队列 (4)
- 存储过程 (8)
- redis (9)
- zookeeper (5)
- 海量数据 (5)
最新评论
-
360pluse:
技术更新,战术升级!Python爬虫案例实战从零开始一站通网盘 ...
Python爬虫实战:Scrapy豆瓣电影爬取 -
18335864773:
推荐用 pageoffice 组件生成 word 文件。
JAVA生成WORD工具类 -
jjhe369:
LISTD_ONE 写道起始地址为163.135.0.1 结束 ...
IP地址与CIDR -
baojunhu99:
private final int POOL_SIZE = 5 ...
使用CompletionService获取多线程返回值 -
LovingBaby:
胡说,javascript 运行时是单线程的,event lo ...
Ajax请求是否可以实现同步
jQuery实现在左边双击某一项时添加到右边,右边时添加到左边:
部分修饰代码简略:
<table style="..."> <tr> <td colspan="2" valign="top" width="47%"> <select multiple="multiple" id="uncountryTable" name="uncountryTable" style="height:300px;width:245px;"> </select> </td> <td align="center"> ... </td> <td colspan="2" valign="top" width="47%"> <select multiple="multiple" id="countryTable" name="countryTable" style="height:300px;width:245px;"> </select> </td> </tr> </table>
以左边为例:
刚开始我的思路是这样的: 当左边select变化时,如果有一项选中,那么当它被双击时就执行相应的操作;但当实施时才发现这样根本不可行,代码如下:
//jQuery("#uncountryTable").change(function(){ //jQuery("#uncountryTable option").each(function(){ //if(jQuery(this).attr("selected") == true){ //jQuery(this).dblclick(function(){ //alert(111111); //var option = "<option value='"+jQuery(this).val()+"'>"+jQuery(this).text()+"</option>"; //jQuery("#countryTable").append(option); //jQuery(this).remove(); //}); //} //}); //});
其实一直到判断选中的这一步都是正确的,经测试此时也确实可以alert出相应选中项的值
(多选下拉框获取选中文本、value: 也可以用change方法)
//jQuery("#uncountryTable").change(function(){ //jQuery("#uncountryTable option").each(function(){ //if(jQuery(this).attr("selected") == true){ //alert(jQuery(this).val()+":"+jQuery(this).text()); //} //}); //});
但是一到dblclick(fn)方法这步就有问题了,连测试的111111都不弹出,几经测试都无效果,无奈只得另谋它路。
在网上搜了一下,发现一个哥们用JS写的同样效果代码(下面),看了之后才发现原来自己想得太复杂了,正确思路应该是这样的: 当双击select的时候,触发dblclick(fn)事件,如果某一项被选中(你双击某一项,它就肯定被选中啦),就将其添加到右边,这样就可以实现效果,哈哈。
上代码:
jQuery(document).ready(function() { jQuery("#uncountryTable").dblclick(function(){ jQuery("#uncountryTable option:selected").each(function(){ var option = "<option value='"+jQuery(this).val()+"'>"+jQuery(this).text()+"</option>"; jQuery("#countryTable").append(option); jQuery(this).remove(); }); }); });
很简单的东西,换下思路就实现了,因此,以后遇到问题时,就先问下自己,是不是我想得太复杂了,哈哈......
那哥们效果+代码(主要部分):
<head> <script> function removeItem(){ var sltSrc=document.getElementById('sltSrc'); var sltTarget=document.getElementById('sltTarget'); for(var i=0;i<sltSrc.options.length;i++) { var tempOption=sltSrc.options[i]; if(tempOption.selected){ sltSrc.removeChild(tempOption); sltTarget.appendChild(tempOption); } } } </script> </head> <body> <select ondblclick="removeItem();" id="sltSrc" multiple="true"> <option value="a">srcA</option> <option value="b">srcB</option> <option value="c">srcC</option> </select> <select ondblclick="addItem();" id="sltTarget" multiple="true"> <option value="a">targetA</option> <option value="b">targetB</option> <option value="c">targetC</option> </select> <div id="showInfo"></div> <input type="button" value="showSelectOptions" onclick="showSelectOptions();"/> </body>
链接:http://www.cnblogs.com/hanxianlong/archive/2009/03/31/1426095.html
发表评论
-
抢购学习
2019-03-01 10:53 1012来源:https://blog.csdn.net/lius ... -
JSONP跨域
2019-02-26 11:31 991jQuery jsonp跨域请求(很详细) json和j ... -
Ajax请求是否可以实现同步
2018-06-14 10:32 5116Ajax请求是否可以实现同步 当JS代码加载到当前A ... -
jQuery新特性总结
2017-09-18 16:00 908$(document).on: 从jQuery1.7开始 ... -
jQuery中map函数
2017-04-06 10:13 1227两种方式: 1、直接jQuery.map //将原数组中 ... -
JS实现的刮刮卡程序
2017-01-05 11:38 2886来源: 基于HTML5 Canvas的刮奖(刮刮卡)小控 ... -
Google插件
2016-06-29 11:56 1419Chrome插件下载 吐血推荐珍藏的Chrome插件 ... -
移动端图片上传解决方案localResizeIMG先压缩后ajax无刷新上传
2016-03-10 09:46 11001现在科技太发达,移动设备像素越来越高,随便一张照片2M+, ... -
使用megapixImage.js定位并展示上传的图片
2016-03-09 18:10 3583megapix-image插件 使用Canvas压缩图片上 ... -
基于jquery实现日历签到功能
2016-02-23 14:05 17715使用Jquery实现每日签到功能 基于jquery实现日 ... -
加载更多
2015-02-05 14:59 3471加载更多: 默认展示第一页数据,向下滑动加载第二页数据,依 ... -
Jquery表单验证插件–Validform
2015-02-05 11:44 20185Validform: Jquery表单验证插件–Valid ... -
EasyUI项目中的自定义JS
2014-07-09 17:15 4948自定义方法: (function($) { ... -
jquery.cookie.js使用介绍
2013-12-30 10:58 2386对cookies的操作在当访问一个网站就无时无刻的都伴随着我 ... -
Jquery打造可以上下移动行的表格
2013-05-06 16:05 3678current.insertBefore(prev); c ... -
[转]JQuery语法总结和注意事项
2011-12-03 13:09 17691、关于页面元素的引用 通过jquery的 $() ... -
jQuery的自动完成插件autocomplete
2011-05-17 14:17 13766autocomplete方法有两个参数,第一个用来填写URL地 ... -
$.ajax中dataType为html实现地区显示效果
2010-12-23 17:00 12169实现了选择第一个时,第二个才显示,并且显示的是对应的信息 ... -
Jquery中的验证jquery.validate.js
2010-12-06 20:03 3443默认验证信息是英文,要改成中文,需引入如下js:jquery. ... -
JQuery插件开发 + 插件
2010-11-03 20:31 2901jQuery插件库 jQuery插件 精品代码 WE ...
相关推荐
- `$("#select1").dblclick(function () {...})`:当用户在`select1`中双击一个选项时,被选中的选项将会被添加到`select2`。这是通过`appendTo()`方法实现的,它将一个或多个DOM元素插入到另一个元素的末尾。 - `...
在本文中,我们将深入探讨如何使用jQuery来实现Select元素之间的内容复制和移动功能。这个功能在许多用户界面中都有应用,比如多选设置、数据过滤等。以下是对给定代码的详细解释和扩展: 首先,我们需要引入jQuery...
select选择框内容左右移动添加删除代码基于jquery-1.8.3.min.js实现,简单实用,选中选项内容,点击移动按钮可进行内容左右移动,双击option内容也可左右移动,支持单选移动、多选移动和一键全部移动! 运行效果图:...
总结来说,这个实例展示了如何使用jQuery来实现两个多选`select`元素之间的选项添加、删除以及值的传递。它利用了`select`元素的`multiple`属性、`input`元素的`hidden`类型,以及jQuery的事件监听和DOM操作功能,...
select选择框内容左右移动添加删除代码基于jquery-1.8.3.min.js实现,简单实用,选中选项内容,点击移动按钮可进行内容左右移动,双击option内容也可左右移动,支持单选移动、多选移动和一键全部移动!
同样,在单击事件`_click`中,如果按下shift键,会遍历当前列表中符合特定索引条件的元素,并为它们添加一个类(is_select),从而实现多选效果。 5. 文件内容中还提到了一些特定的类名和选择器(如.item、is_...
【基于ztree开发的下拉树控件ztree-select】是一种高效的前端UI组件,它结合了ztree的核心特性和下拉菜单的功能,适用于构建具有层级结构的选中项。ztree是一个广泛使用的JavaScript树形插件,而ztree-select则是其...
JQuery实现角色左右选择特效是一种基于JQuery库的网页交互设计技术,它允许用户通过界面操作,将选项在两个列表框之间相互转移。本技术适用于需要角色权限设置、物品分类、表单选项等多选转移的场景。 在本技术实现...
例如,当用户点击id为“add”的按钮时,`$('#select1 option:selected')`会选择被选中的选项,然后使用`appendTo('#select2')`将它们添加到右侧的下拉框中。同理,`$('#remove')`和`$('#remove_all')`则是将选中或...
具体实现时,需要先阻止默认事件,以防止其他默认行为干扰,例如页面滚动等。然后,调用一个自定义的函数处理双击事件。自定义函数"dblclick_node"需要对传入的节点对象进行处理,确认这是一个有效的节点,并执行...
本篇文章主要探讨了三种流行的JavaScript库——Extjs、Jquery、Dhtmlxtree中实现树形结构(Tree)的方法及其差异。树形结构在用户界面设计中扮演着重要的角色,尤其是在展现具有层级关系的数据时。下面我们将分别...
双击"select1"中的选项会将其添加到"select2",而双击"select2"中的选项则会将其移回"select1"。 通过这种方式,jQuery使得在下拉框之间移动选项变得非常简单。用户可以通过点击按钮或双击选项来实时调整选择,提高...
默认值是1,如果设置为0,则在输入框内双击或删除输入框内容时也会显示下拉列表。 2. width:用于指定下拉框的宽度,如果不设置,则默认为输入元素的宽度。 3. max:指定下拉列表中显示的项目数量,当项目过多时,...
如果需要在运行时动态添加或删除选项,可以使用jQuery的`.append()`和`.remove()`方法。这在需要根据用户输入或其他条件更新选择框内容的场景中非常有用。 6. **优化性能**: 对于大量选项,避免使用`.each()`...
select选择框内容左右移动添加删除代码基于jquery-1.8.3.min.js实现,简单实用,选中选项内容,点击移动按钮可进行内容左右移动,双击option内容也可左右移动,支持单选移动、多选移动和一键全部移动!