select 元素可创建单选或多选菜单。当提交表单时,浏览器会提交选定的项目,或者收集用逗号分隔的多个选项,将其合成一个单独的参数列表,并且在将 <select> 表单数据提交给服务器时包括 name 属性。

一、基本用法:

<select>

<option value ="volvo">Volvo</option>

<option value ="saab">Saab</option>

<option value="opel">Opel</option>

<option value="audi">Audi</option>

</select>

其中,</option>标签可以省掉,在页面中用法

<SELECT NAME="studyCenter" id="studyCenter"  SIZE="1">

<OPTION VALUE="0">全部

<OPTION VALUE="1">湖北电大网络学习中心

<OPTION VALUE="2">成都师范学院网络学习中心

<OPTION VALUE="3">武汉职业技术学院网络学习中心

</SELECT>

二、Select元素还可以多选,看如下代码:

//有multiple属性,则可以多选

<select name= “education” id=”education” multiple=”multiple”>

       <option value=”1”>高中</option>

       <option value=”2”>大学</option>

       <option value=”3”>博士</option>

</select>



//下面没有multiple属性
, 只显示一条,不能多选

<select name= “education” id=”education” >

       <option value=”1”>高中</option>

       <option value=”2”>大学</option>

       <option value=”3”>博士</option>

</select>

//下面是设置了size属性的情况
, 如果size = 3
那么就显示三条数据,注意不能多选的。

<select name="education" id="education" size='3'>

         <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>

         <option selected>请选择</option>

</select>

三、 多选Select组件涉及的所有常用操作:

1.     
判断select选项中是否存在指定值的Item

@param objSelectId
将要验证的目标select组件的id

@param objItemValue
将要验证是否存在的值

function isSelectItemExit(objSelectId,objItemValue)  { 


 var objSelect = document.getElementById(objSelectId);

    var isExit = false; 

    if (null != objSelect && typeof(objSelect) != "undefined") {

     for(var i=0;i<objSelect.options.length;i++) { 

         if(objSelect.options[i].value == objItemValue) { 

             isExit = true; 

             break; 

         } 

     } 

    }

    return isExit;

 }

2.     
向select选项中加入一个Item

@param  objSelectId 将要加入item的目标select组件的id

@param objItemText 将要加入的item显示的内容

@param objItemValue 将要加入的item的值

function addOneItemToSelect(objSelectId,objItemText,objItemValue) { 


 var objSelect = document.getElementById(objSelectId);

    if (null != objSelect && typeof(objSelect) != "undefined") {

      //判断是否该值的item已经在select中存在


     if(isSelectItemExit(objSelectId,objItemValue)) { 

         $.messager.alert('提示消息','该值的选项已经存在!','info');

     }  else  {

         var varItem = new Option(objItemText,objItemValue); 

         objSelect.options.add(varItem); 

     } 

    }

}

3.   
从select选项中删除选中的项,支持多选多删

@param objSelectId 将要进行删除的目标select组件id

function removeSelectItemsFromSelect(objSelectId) { 


 var objSelect = document.getElementById(objSelectId);

 var delNum = 0;

     if (null != objSelect && typeof(objSelect) != "undefined") {

        for(var i=0;i<objSelect.options.length;i=i+1) { 

            if(objSelect.options[i].selected) { 

                objSelect.options.remove(i); 

                delNum = delNum + 1;

                i = i - 1;

            } 

        }        

     if (delNum <= 0 ) {

      $.messager.alert('提示消息','请选择你要删除的选项!','info');

     } else {

      $.messager.alert('提示消息','成功删除了'+delNum+'个选项!','info');

     }

     }

}

4.     
从select选项中按指定的值删除一个Item  


  @param objSelectId 将要验证的目标select组件的id

  @param objItemValue 将要验证是否存在的值

function removeItemFromSelectByItemValue(objSelectId,objItemValue) { 


 var objSelect = document.getElementById(objSelectId);

     if (null != objSelect && typeof(objSelect) != "undefined") {

      //判断是否存在

       if(isSelectItemExit(objSelect,objItemValue)) { 

         for(var i=0;i<objSelect.options.length;i++) { 

             if(objSelect.options[i].value == objItemValue) { 

                 objSelect.options.remove(i); 

                 break; 

             } 

         }        

         $.messager.alert('提示消息','成功删除!','info');            


     } else { 

         $.messager.alert('提示消息','不存在指定值的选项!','info'); 


     }    

     }

}

5.     
清空select中的所有选项

@param objSelectId 将要进行清空的目标select组件id

function clearSelect(objSelectId) { 

 var objSelect = document.getElementById(objSelectId);

     if (null != objSelect && typeof(objSelect) != "undefined") {

        for(var i=0;i<objSelect.options.length;) { 

          objSelect.options.remove(i); 

        }        

     }

}

6.
获取select中的所有item,并且组装所有的值为一个字符串,值与值之间用逗号隔开

 @param objSelectId 目标select组件id

 @return select中所有item的值,值与值之间用逗号隔开

function getAllItemValuesByString(objSelectId) {

 var selectItemsValuesStr = "";

 var objSelect = document.getElementById(objSelectId);

 if (null != objSelect && typeof(objSelect) != "undefined") {

      var length = objSelect.options.length

        for(var i = 0; i < length; i = i + 1) { 

         if (0 == i) {

            selectItemsValuesStr = objSelect.options[i].value;

         } else {

            selectItemsValuesStr = selectItemsValuesStr + "," + objSelect.options[i].value;

         }

        }  

     } 

     return selectItemsValuesStr;

}

7.
将一个select中的所有选中的选项移到另一个select中去

  @param fromObjSelectId  移动item的原select组件id

  @param toObjectSelectId  移动item将要进入的目标select组件id

 function moveAllSelectedToAnotherSelectObject(fromObjSelectId, toObjectSelectId) { 


 var objSelect = document.getElementById(fromObjSelectId);

 var delNum = 0;

     if (null != objSelect && typeof(objSelect) != "undefined") {

        for(var i=0;i<objSelect.options.length;i=i+1) { 

            if(objSelect.options[i].selected) { 

                addOneItemToSelect(toObjectSelectId,objSelect.options[i].text,objSelect.options[i].value)

                objSelect.options.remove(i);

                i = i - 1;

            }

        }        

     }

}

8.
将一个select中的所有选项移到另一个select中去

 @param fromObjSelectId 
移动item的原select组件id

 @param toObjectSelectId  移动item将要进入的目标select组件id

 function moveAllToAnotherSelectObject(fromObjSelectId, toObjectSelectId) { 

 var objSelect = document.getElementById(fromObjSelectId);

     if (null != objSelect) {

      for(var i=0;i<objSelect.options.length;i=i+1) { 

             addOneItemToSelect(toObjectSelectId,objSelect.options[i].text,objSelect.options[i].value)

             objSelect.options.remove(i);

             i = i - 1;

        }  

     }

}

HTML中select标签单选多选详解的更多相关文章

  1. maven 依赖中scope标签的配置范围详解

    在创建Maven项目时,需要在pom.xml 文件中添加相应的依赖,其中有一个scope标签,该标签是设置该依赖范围 (maven项目包含三种classpath{编译classpath,测试class ...

  2. spring中bean标签factory-method和factory-bean)详解工厂方法(factory-method和factory-bean)

    转自:http://blog.sina.com.cn/s/blog_6d3c1ec601019f3j.html A.factory-method The name of a factory metho ...

  3. 《手把手教你》系列技巧篇(三十二)-java+ selenium自动化测试-select 下拉框(详解教程)

    1.简介 在实际自动化测试过程中,我们也避免不了会遇到下拉选择的测试,因此宏哥在这里直接分享和介绍一下,希望小伙伴或者童鞋们在以后工作中遇到可以有所帮助. 2.select 下拉框 2.1Select ...

  4. (转载) Linux IO模式及 select、poll、epoll详解

    注:本文是对众多博客的学习和总结,可能存在理解错误.请带着怀疑的眼光,同时如果有错误希望能指出. 同步IO和异步IO,阻塞IO和非阻塞IO分别是什么,到底有什么区别?不同的人在不同的上下文下给出的答案 ...

  5. Python中操作mysql的pymysql模块详解

    Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...

  6. (转)Linux IO模式及 select、poll、epoll详解

    本文为转载,并作了部门调整.修改. [原文出处:https://segmentfault.com/a/1190000003063859] 同步IO和异步IO,阻塞IO和非阻塞IO分别是什么,到底有什么 ...

  7. 【转】angularjs指令中的compile与link函数详解

    这篇文章主要介绍了angularjs指令中的compile与link函数详解,本文同时诉大家complie,pre-link,post-link的用法与区别等内容,需要的朋友可以参考下   通常大家在 ...

  8. 网络通信 --> IO多路复用之select、poll、epoll详解

    IO多路复用之select.poll.epoll详解      目前支持I/O多路复用的系统调用有 select,pselect,poll,epoll,I/O多路复用就是通过一种机制,一个进程可以监视 ...

  9. angularjs指令中的compile与link函数详解

    这篇文章主要介绍了angularjs指令中的compile与link函数详解,本文同时诉大家complie,pre-link,post-link的用法与区别等内容,需要的朋友可以参考下   通常大家在 ...

随机推荐

  1. Oracle RAC 环境下的连接管理

    http://blog.csdn.net/cyxlxp8411/article/details/7634003

  2. Android App Widget的简单使用

    App Widget是一些桌面的小插件,比如说天气和某些音乐播放应用,放到桌面去的那部分: 例如: 实现步骤及代码如下: (1)首先,在AndroidManifest.xml中声明一个App Widg ...

  3. [置顶] js对象

    js中,一切事物都是对象.对象是一切的基础. 而具体到某一个对象时. 对象则是包含一组变量和函数的集合实例 我们先来中体会下je对象的全局. 接下来就具体揭开这个对象的面纱吧 ja对象分类 Funct ...

  4. 第23讲 UI_布局 之相对布局

    第23讲 UI_布局 之相对布局 .RelativeLayout(相对布局): RelativeLayout(相对布局)是指组件的位置总是相对兄弟组件.父容器来决定的(相对位置),如某个组件的左边右边 ...

  5. IOS 缩放图片常用方法

    /** * 指定Size压缩图片 (图片会压缩变形) * * @param image 原图 * @param size 压缩size * * @return 压缩后的图片 */ -(UIImage* ...

  6. ASIHttpRequest:创建队列、下载请求、断点续传、解压缩

    ps:本文转载自网络:http://ryan.easymorse.com/?p=12 感谢作者 工程完整代码下载地址:RequestTestDownload1 可完成: 下载指定链接的zip压缩文件 ...

  7. 关于C#中的弱引用

    本文前部分来自:http://www.cnblogs.com/mokey/archive/2011/11/24/2261605.html 分割线后为作者补充部分. 一:什么是弱引用 了解弱引用之前,先 ...

  8. hdu 3056 病毒侵袭持续中 AC自己主动机

    http://acm.hdu.edu.cn/showproblem.php?pid=3065 刘汝佳的模板真的非常好用,这道题直接过 学到: cnt数组记录单词出现次数 以及map存储单词编号与字符串 ...

  9. C++刷称号——2707: 素数与要素

    Description 从键盘输入的随机整数n,如果n不是质数,然后计算n所有的因素(不含1).例如,对于16,出口2,4,8:否则输出"It is a prime number." ...

  10. android设备之间屏幕共享

    近期公司在开发一款android的设备把屏幕投射到手机上.同一时候手机还能够触控.键盘操作.这样.就达到了屏幕共享的目的. 思考了一下.主要思路: 1.将截图所获取的位图用ffmpeg编码成视频流. ...