javascript中select下拉框的用法总结


Posted in Javascript onJanuary 07, 2016

本文针对开发项目中遇到的问题,进行了汇总
问题1:如何选择select的option里面的值?
首先会用到一个方法 onchange();这个方法主要用于触发,选择框内容改变时间

实现代码:

<!doctype html>
<html>
<head lang="en">
 <meta charset="UTF-8">
</head>
<body>
 <select onchange="test(event)">
  <option>安静</option>
  <option>晴天</option>
  <option>七里香</option>
 </select>
 <script type="text/javascript">
  function test (e) {
   var e = event ? event : window.event;
   alert(e.target.value);
  }
 </script>
</body>
</html>

javascript中select下拉框的用法总结

问题2:可是在开发中,我们一般选择了内容只是为了显示,而真正要做的是和后台进行交互数据传输,这时候,我们为了尽可能减少http数据传输,所以一般会传 id 等作为数据传输标志,如何做?
开发中,option一般都是动态创建的,那么这时候,我们只需要给你动态创建一个自定义属性。那么如何获取自定义属性呢?

<!doctype html>
<html>
<head lang="en">
 <meta charset="UTF-8">
</head>
<body>

 <select onchange="test(event)" id="sel"></select>

 <script type="text/javascript">
  //定义内容的json数据,一般从后台获取
  var data = [
   {
    name: '晴天',
    id: '1'
   },
   {
    name: '安静',
    id: '2'
   },
   {
    name: '七里香',
    id: '3'
   }
  ];

  createOption('sel',data);
  //创建option
  function createOption(parentId, data){
   var parentId = document.getElementById(parentId);
   for(var i=0; i<data.length; i++){
    var opt = document.createElement('option');
    //设置option的值
    opt.innerHTML = data[i].name;
    //定义option的自定义值
    opt.setAttribute('dataid', data[i].id);
    parentId.appendChild(opt);
   }
  }
  //选取自定义属性的方法
  function test (e) {
   var e = event ? event : window.event;
   var target = e.target;
   var index = target.selectedIndex;
   alert("我的id="+target[index].getAttribute('dataid'));
  }
 </script>
</body>
</html>

结果图如下:

javascript中select下拉框的用法总结

如果大家还想深入学习,可以点击jquery下拉框效果汇总、JavaScript下拉框效果汇总进行学习。

这就是我在开发中遇到的问题,希望可以对大家的学习有所启发。

Javascript 相关文章推荐
syntaxhighlighter 使用方法
Jul 02 Javascript
javascript一个无懈可击的实例化XMLHttpRequest的方法
Oct 13 Javascript
js 时间格式与时间戳的相互转换示例代码
Dec 25 Javascript
jquery选择checked在ie8普通模式下的问题
Feb 12 Javascript
js实现人才网站职位选择功能的方法
Aug 14 Javascript
Vue.js每天必学之过渡与动画
Sep 06 Javascript
JavaScript 中 avalon绑定属性总结
Oct 19 Javascript
bootstrap实现动态进度条效果
Mar 08 Javascript
Express使用html模板的详细代码
Sep 18 Javascript
vuejs 动态添加input框的实例讲解
Aug 24 Javascript
vue中音频wavesurfer.js的使用方法
Feb 20 Vue.js
微信小程序实现下拉加载更多商品
Dec 29 Javascript
详解JS中Array对象扩展与String对象扩展
Jan 07 #Javascript
js创建对象的方法汇总
Jan 07 #Javascript
JavaScript截取、切割字符串的技巧
Jan 07 #Javascript
js确认框confirm()用法实例详解
Jan 07 #Javascript
实例讲解jquery与json的结合
Jan 07 #Javascript
javascript仿百度输入框提示自动下拉补全
Jan 07 #Javascript
基于jquery实现表格无刷新分页
Jan 07 #Javascript
You might like
新版PHP将向Java靠拢
2006/10/09 PHP
1.PHP简介
2006/10/09 PHP
php中使用in_array() foreach array_search() 查找数组是否包含时的性能对比
2015/04/14 PHP
php实现word转html的方法
2016/01/22 PHP
IE6、IE7中获取Button元素的值的bug说明
2011/08/28 Javascript
JavaScript中的Math.sin()方法使用详解
2015/06/15 Javascript
浅谈Jquery核心函数
2015/06/18 Javascript
Javascript打印局部页面实例
2016/06/21 Javascript
javascript-解决mongoose数据查询的异步操作
2016/12/22 Javascript
Angular.JS去掉访问路径URL中的#号详解
2017/03/30 Javascript
AngularJS标签页tab选项卡切换功能经典实例详解
2018/05/16 Javascript
Mint-UI时间组件起始时间问题及时间插件使用
2018/08/20 Javascript
JavaScript时间与时间戳的转换操作实例分析
2018/12/07 Javascript
微信小程序自定义多列选择器使用详解
2019/06/21 Javascript
vue的路由映射问题及解决方案
2019/10/14 Javascript
Bootstrap告警框(alert)实现弹出效果和短暂显示后上浮消失的示例代码
2020/08/27 Javascript
移动端JS实现拖拽两种方法解析
2020/10/12 Javascript
Python安装Imaging报错:The _imaging C module is not installed问题解决方法
2014/08/22 Python
python实现在无须过多援引的情况下创建字典的方法
2014/09/25 Python
详解Python3.1版本带来的核心变化
2015/04/07 Python
python实现bucket排序算法实例分析
2015/05/04 Python
python数据结构之链表详解
2017/09/12 Python
Python3简单实例计算同花的概率代码
2017/12/06 Python
python numpy 部分排序 寻找最大的前几个数的方法
2018/06/27 Python
python实现飞船大战
2020/04/24 Python
Python爬虫之Selenium多窗口切换的实现
2020/12/04 Python
Python+Opencv实现把图片、视频互转的示例
2020/12/17 Python
基于Python-turtle库绘制路飞的草帽骷髅旗、美国队长的盾牌、高达的源码
2021/02/18 Python
CSS3之背景尺寸Background-size使用介绍
2013/10/14 HTML / CSS
Java提供了哪些企业应用编程接口
2015/02/13 面试题
机械制造专业个人的自我评价
2013/12/28 职场文书
《兰亭集序》教学反思
2014/02/11 职场文书
群教个人对照检查材料
2014/08/20 职场文书
工地例会施工汇报材料
2014/08/22 职场文书
五年级下册复习计划
2015/01/19 职场文书
MySQL 查询速度慢的原因
2021/05/25 MySQL