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. div 居中进行总结

    1.margin:auto ;让元素居中,需要确定元素的宽度,并且需要是块元素 eg: div { width:200px; height:200px; background:#222; margin ...

  2. 安装notepad++之后怎样在鼠标右键上加上Edit with notepad++

    在鼠标右键上加入使用notepad++编辑 我们在安装完notepad++文本编辑器之后,在一个文本文件上右键有时候并没有出现"使用notepad++编辑的选项",我们可以通过简单 ...

  3. Commons Beanutils使用setProperty() - 就是爱Java

    有时不能只依靠getter/setter操作bean,如:需要名字动态取得的,或是访问bean内的field,甚至是集合或数组内bean的field,利用反射机制对bean的field进行处理,这时候 ...

  4. Activity 模版样式简介

    1:对话框样式. <activity android:theme="@android:style/Theme.Dialog"> 2:透明样式. <activity ...

  5. leetcode_Search in Rotated Sorted Array II

    Follow up for "Search in Rotated Sorted Array": What if duplicates are allowed? Would this ...

  6. KEIL中的一些细节

    1.KEIL中的指针: 基于存储器的指针:数据类型 [指向存储区]  *[ 指针存储区]指针变量 char xdata * px //px本身存在于自动分配的空间,一般位于data中,指向的内容位于x ...

  7. MySQL数据库 常用操作

    1:使用SHOW语句找出在服务器上当前存在什么数据库: mysql> SHOW DATABASES; 2:创建一个数据库MYSQLDATA mysql> CREATE DATABASE M ...

  8. jsf标签,jsp标签与jstl标签

    JSF通过定制标签与JSP集成.之前展示过的所有 JSF标签,<h:inputText>.<h:outputText>.<h:form> 和<f:view&g ...

  9. ORACLE SEQUENCE 介绍

    在oracle中sequence就是所谓的序列号,每次取的时候它会自己主动添加,一般用在须要按序列号排序的地方.  1.Create Sequence  你首先要有CREATE SEQUENCE或者C ...

  10. [Redux] Extracting Container Components -- Complete

    Clean TodoApp Component, it doesn't need to receive any props from the top level component: const To ...