转载请注明来源:https://www.cnblogs.com/hookjc/

function FlySwapSelect(s1,s2,myvars,calldbclick)
{
 var mSel1=s1;
 var mSel2=s2;
 var mThis=this;
 var mVars=myvars.split('|');
 var mCallDbClick=calldbclick;
 mSel1.attachEvent('ondblclick',function(){mThis.SwapOptions(mSel1,mSel2);});
 mSel2.attachEvent('ondblclick',function(){mThis.SwapOptions(mSel2,mSel1);});

//双击事件的处理
 this.SwapOptions=function(from,to)
 {
  if(from.selectedIndex<0) return;
  var op1=from.options[from.selectedIndex];
  //如果为空
  if(op1.innerHTML=='') return;
  var op2=new Option(op1.text,op1.value);
  var len=to.options.length;
  to.options[len]=op2;
  for(var i=0;i<mVars.length;i++)
   to.options[len].setAttribute(mVars[i],op1.getAttribute(mVars[i]));
  from.options[from.selectedIndex]=null;
  if(mCallDbClick!='')eval(mCallDbClick+'();');
 }
 this.GetSum=function(obj,str)
 {
  var ret=new Array();
  arr=str.split("|");
  for(var n=0;n<arr.length;n++)
   ret[n]=0;
  for(i=0;i<obj.options.length;i++)
  {
   for(var n=0;n<arr.length;n++)
    ret[n]+=obj.options[i].getAttribute(arr[n])*1;
  }
  return ret;
 }
 //根据查询条件筛选
 this.Query=function(sel,where)
 {
  for(i=0;i<sel.options.length;i++)
  {
   t=sel.options[i];
   var ret=eval(where);
   if(ret)
   {
    if(sel.options[i].innerHTML=='')
     sel.options[i].innerHTML=sel.options[i].oldtxt;
   }else
   {
    if(sel.options[i].innerHTML!='')
    {
     sel.options[i].oldtxt=sel.options[i].innerHTML;
     sel.options[i].innerHTML='';
    }
   }
  }
  this.Sort(sel);
 }

排序:
 this.Sort=function(obj)
 {
  var arr = new Array();
  
  var len=obj.options.length;
  for(var i=0; i<len; i++)
  {
   var attrs = new Array();
   for(var n=0;n<mVars.length;n++)
    attrs[n]=obj.options[i].getAttribute(mVars[n]);
   attrs[n]=obj.options[i].getAttribute('oldtxt');
   arr[i]={text:obj.options[i].innerHTML,html:obj.options[i].value,attr:attrs};
  }
  arr.sort(this.SortFun);
  
  for(var i=0; i<len; i++)
  {
   obj.options[i].innerHTML=arr[i].text;
   obj.options[i].value=arr[i].value;
   for(var n=0;n<mVars.length;n++)
    obj.options[i].setAttribute(mVars[n],arr[i].attr[n]);
   obj.options[i].oldtxt=arr[i].attr[n];
  }
 }
 this.SortFun=function(x,y){if(x.text>y.text) return -1; else if(x.text<y.text) return 1;else return 0;}
 this.GetData=function(obj)
 {
  ret='';
  for(i=0;i<obj.options.length;i++)
   ret+=','+obj.options[i].value;
   return ret.substr(1);
 }
}

来源:python脚本自动迁移

<select><option></option></select> 操作的更多相关文章

  1. 让 select 的 option 标签支持事件监听(如复制操作)

    这标题,让option支持事件监听,应该不难的呀,有什么好讲的? 其实还是有的,默认在浏览器代码是无法直接对option标签进行操作的,不仅包括JS事件监听,还是CSS样式设置 查了一些资料,姑且认为 ...

  2. js 操作select和option

    js 操作select和option 1.动态创建select function createSelect(){ var mySelect = document.createElement_x(&qu ...

  3. jQuery获取Radio选择的Value值||两个select之间option的互相添加操作(jquery实现)

    jQuery获取Radio选择的Value值: 1. $("input[name='radio_name'][checked]").val();  //选择被选中Radio的Val ...

  4. jquery操作select下拉框的各种方法,获取选中项的值或文本,根据指定的值或文本选中select的option项等

    简介jquery里对select进行各种操作的方法,如联动.取值.根据值或文本来选中指定的select下拉框指定的option选项,读取select选中项的值和文本等. 这一章,站长总结一下jquer ...

  5. vue操作select获取option值

    如何实时的获取你选中的值 只用@change件事 @change="changeProduct($event)" 动态传递参数 vue操作select获取option的ID值 如果 ...

  6. js 操作select和option常见用法

    1.获取选中select的value和text,html <select id="mySelect"> <option value="1"&g ...

  7. jquery的select元素和option的相关操作

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. javaScript的select元素和option的相关操作

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. select标签的相关操作,选中,获取option的值,二级联动

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  10. AngularJS下拉列表select在option动态变化之后多出了一个错误项的问题

    场景: Select初始化之后,选中select的某个选项 通过AngularJS更新select的选项 错误写法: HTML(使用ng-repeat) <div ng-app="Te ...

随机推荐

  1. 如何优雅地读写HttpServletRequest和HttpServletResponse的请求体

    最近很多交互要同原生的HttpServletRequest和HttpServletResponse打交道.从HttpServletRequest中读取body数据封装成某种数据结构:向HttpServ ...

  2. Java程序设计基础笔记 • 【第4章 条件结构】

    全部章节   >>>> 本章目录 4.1 条件结构 4.1.1 程序流程控制 ​4.1.2 单分支if结构 4.1.3 双分支if结构 4.1.4 实践练习 4.2 多重条件结 ...

  3. .net core中的Options重新加载机制

    Options是.net core提出的一种辅助配置机制,即选项. 目前,我们可以使用的Options有五种(源码): IOptionsFactory<>:Options的创建工厂(Sin ...

  4. C# string.Format 和 String.Format 的区别

    string.Format 和 String.Format  ,不论是用法还是意思,都是一样的 怎么使用? 通过 占位符来替换 ,类似于 Replace 的操作 string s = string.F ...

  5. SQL server - if else 与 else if 的正确使用

    两层判断 if a>2 begin print 'a大于2' end else begin print 'a小于等于2' end 注意了  begin - end 之间的代码块不允许空,必须有指 ...

  6. PowerShell 管道符之Select的使用方法【一】

    之前我文章中我们略微提到过管道符的操作,但并不多,这篇主要讲解一下详细的使用方法 假设我们要对数组中的数字1-10中我想要从右往左换句话说就是从字符串最后一个字开始倒过来往前数截取6个子字符串时可以这 ...

  7. SYCOJ411

    题面描述 MasMas在面试某大厂时遇到了一道有趣的题.面试官要求MasMas写一个程序找出几个数中,出现次数为奇数的那个数.MasMas抓耳挠腮,请你帮帮他. 输入描述 第一行输入一个数nn (1 ...

  8. Linux防火墙--IPtables企业级配置策略思路

    一.防火墙简介 防火墙定义:是通过有机结合各类用于安全管理与筛选的软件和硬件设备,帮助计算机网络于其内.外网之间构建一道相对隔绝的保护屏障,以保护用户资料与信息安全性的一种技术. 防火墙发展应用:最早 ...

  9. 一文看懂B端产品和C端产品

    大纲 什么是B端产品 什么是C端产品 为什么会产生B端产品和C端产品 怎么判断一个产品是B端还是C端 B端产品和C端产品存在哪些差异 C端产品经理如何向B端产品经理转型 写在最后   什么是B, Bu ...

  10. 输出2到n之间的全部素数

    本题要求输出2到n之间的全部素数,每行输出10个.素数就是只能被1和自身整除的正整数.注意:1不是素数,2是素数. 输入格式: 输入在一行中给出一个长整型范围内的整数. 输出格式: 输出素数,每个数占 ...