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. iOS 第三方 需要 引用的库

    ================================================== AFNetWorking   是基于 nsurlconnection   所以不需要引入库 === ...

  2. objc runtime 动态增加属性

    objective-c中,有类别可以在不修改源码的基础上增加方法:近排在看别人的开源代码时,发现还可以动态增加属性.而且是在运行时,太牛B了. 使用运行时库,必须要先引入 objc/runtime.h ...

  3. [SQL注入2]FROM SQL INJECTION TO SHELL: POSTGRESQL EDITION

    FROM SQL INJECTION TO SHELL: POSTGRESQL EDITION 这里先介绍一下POSTGRESQL.这是一款数据库管理系统,与oracle是同类型软件.08年左右的市场 ...

  4. cf B. Valera and Contest

    http://codeforces.com/contest/369/problem/B 先对k个处理,先处理sk%k个为sk/k+1,如果sk/k==0,k个数都为sk/k:对与剩下的数也按照同样的方 ...

  5. cf Strings of Power

    http://codeforces.com/contest/318/problem/B #include <cstdio> #include <cstring> #includ ...

  6. bat命令大全

    一.简单批处理内部命令简介 1.Echo 命令 打开回显或关闭请求回显功能,或显示消息.如果没有任何参数,echo 命令将显示当前回显设置.   语法 echo [{on│off}] [message ...

  7. 批量更新sql |批量update sql

    图所示现需要批量更新table2表内字段Pwd更新userName对IP地址username与Ip对应关系table1所示 update table2 set pwd=table1.ip from t ...

  8. Annotation(四)——Struts2注解开发

    Hibernate和Spring框架的开发前边总结了,这次看一下流行的MVC流程框架Struts2的注解开发吧.Struts2主要解决了从JSP到Action上的流程管理,如何进行Uri和action ...

  9. Netty实例-简单的服务端-client实现,凝视具体

           书籍推荐:                                       实例代码 :http://download.csdn.net/detail/jiangtao_st ...

  10. Android Action Bar 详解篇 .

    作者原创,转载请标明出处:http://blog.csdn.net/yuxlong2010 作为Android 3.0之后引入的新的对象,ActionBar可以说是一个方便快捷的导航神器.它可以作为活 ...