`
flashdream8
  • 浏览: 680465 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

jquery 动态加载 select

 
阅读更多

jquery 动态加载 select

 

 

var d = '';
	function show(sel){
		if(d==''){
			$.getJSON('${basePath}item/getItemsByPid.do?d='+new Date().getTime(),{pid:2},
					function(data){
					   d = data;
						if(d!=''){
							//var s = $('#gradeid');
							var s = $(sel);  // DOM 对象转化为jquery对象
							s.empty();//清除select中的 option
							$.each(d,function(index,item){
								var opt = $("<option>").text(item.name).val(item.id);
								s.append(opt);
							});
						}else{
							alert('初始化错误!');
							d = '';
						}
					});
		}
	}

 

    ajax 动态获得的 json数组 

[{"id":3,"name":"幼儿班" }

,{"id":4,"name":"一年级" }
,{"id":5,"name":"二年级" }
,{"id":6,"name":"三年级" }
,{"id":7,"name":"四年级" }
,{"id":8,"name":"五年级" }
,{"id":9,"name":"六年级" }
,{"id":10,"name":"七年级"}
,{"id":11,"name":"八年级"}
,{"id":12,"name":"九年级"}]
 

 

html:

 

 

<select name="gradeid" id="gradeid" onfocus="show(this);">
        			<option value="-1">--请选择--</option>
        		</select>

 

 

 

===============================

 

 

//遍历option和添加、移除option
function changeShipMethod(shipping){
 var len = $("select[@name=ISHIPTYPE] option").length
 if(shipping.value != "CA"){
  $("select[@name=ISHIPTYPE] option").each(function(){
   if($(this).val() == 111){
    $(this).remove();
   }
  });
 }else{
  $("<option value='111'>UPS Ground</option>").appendTo($("select[@name=ISHIPTYPE]"));
 }
}


//取得下拉选单的选取值

$('#testSelect option:selected').text();
或$("#testSelect").find('option:selected').text();
或$("#testSelect").val();
//////////////////////////////////////////////////////////////////
记性不好的可以收藏下:
1,下拉框:

var cc1   = $(".formc select[@name='country'] option[@selected]").text(); //得到下拉菜单的选中项的文本(注意中间有空格)
var cc2 = $('.formc select[@name="country"]').val();   //得到下拉菜单的选中项的值
var cc3 = $('.formc select[@name="country"]').attr("id"); //得到下拉菜单的选中项的ID属性值
$("#select").empty();//清空下拉框//$("#select").html('');
$("<option value='1'>1111</option>").appendTo("#select")//添加下拉框的option

稍微解释一下:
1.select[@name='country'] option[@selected] 表示具有name 属性,
并且该属性值为'country' 的select元素 里面的具有selected 属性的option 元素;
可以看出有@开头的就表示后面跟的是属性。

2,单选框:
$("input[@type=radio][@checked]").val();   //得到单选框的选中项的值(注意中间没有空格)
$("input[@type=radio][@value=2]").attr("checked",'checked'); //设置单选框value=2的为选中状态.(注意中间没有空格)

3,复选框:
$("input[@type=checkbox][@checked]").val(); //得到复选框的选中的第一项的值
$("input[@type=checkbox][@checked]").each(function(){ //由于复选框一般选中的是多个,所以可以循环输出
   alert($(this).val());
   });

$("#chk1").attr("checked",'');//不打勾
$("#chk2").attr("checked",true);//打勾
if($("#chk1").attr('checked')==undefined){} //判断是否已经打勾


当然jquery的选择器是强大的. 还有很多方法.

<script src="jquery-1.2.1.js" type="text/javascript"></script>
<script language="javascript" type="text/javascript">
$(document).ready(function(){
$("#selectTest").change(function()
{
       //alert("Hello");
       //alert($("#selectTest").attr("name"));
       //$("a").attr("href","xx.html");
       //window.location.href="xx.html";
       //alert($("#selectTest").val());
       alert($("#selectTest option[@selected]").text());
       $("#selectTest").attr("value", "2");

});
});
</script>


<a href="#">aaass</a>

<!--下拉框-->
<select id="selectTest" name="selectTest">
<option value="1">11</option>
<option value="2">22</option>
<option value="3">33</option>
<option value="4">44</option>
<option value="5">55</option>
<option value="6">66</option>
</select>
jquery radio取值,checkbox取值,select取值,radio选中,checkbox选中,select选中,及其相关获取一组radio被选中项的值
var item = $('input[@name=items][@checked]').val();
获取select被选中项的文本
var item = $("select[@name=items] option[@selected]").text();
select下拉框的第二个元素为当前选中值
$('#select_id')[0].selectedIndex = 1;
radio单选组的第二个元素为当前选中值
$('input[@name=items]').get(1).checked = true;
获取值:
文本框,文本区域:$("#txt").attr("value");
多选框checkbox:$("#checkbox_id").attr("value");
单选组radio: $("input[@type=radio][@checked]").val();
下拉框select: $('#sel').val();
控制表单元素:
文本框,文本区域:$("#txt").attr("value",'');//清空内容
                $("#txt").attr("value",'11');//填充内容
多选框checkbox: $("#chk1").attr("checked",'');//不打勾
                $("#chk2").attr("checked",true);//打勾
                if($("#chk1").attr('checked')==undefined) //判断是否已经打勾
单选组radio: $("input[@type=radio]").attr("checked",'2');//设置value=2的项目为当前选中项
下拉框select: $("#sel").attr("value",'-sel3');//设置value=-sel3的项目为当前选中项
            $("<optionvalue='1'>1111</option><optionvalue='2'> 2222</option>").appendTo("#sel")//添加下拉框的option
            $("#sel").empty();//清空下拉框

获取一组radio被选中项的值
var item = $('input[@name=items][@checked]').val();
获取select被选中项的文本
var item = $("select[@name=items] option[@selected]").text();
select下拉框的第二个元素为当前选中值
$('#select_id')[0].selectedIndex = 1;
radio单选组的第二个元素为当前选中值
$('input[@name=items]').get(1).checked = true;
获取值:
文本框,文本区域:$("#txt").attr("value");
多选框checkbox:$("#checkbox_id").attr("value");
单选组radio: $("input[@type=radio][@checked]").val();
下拉框select: $('#sel').val();
控制表单元素:
文本框,文本区域:$("#txt").attr("value",'');//清空内容
$("#txt").attr("value",'11');//填充内容
多选框checkbox: $("#chk1").attr("checked",'');//不打勾
$("#chk2").attr("checked",true);//打勾
if($("#chk1").attr('checked')==undefined) //判断是否已经打勾
单选组radio: $("input[@type=radio]").attr("checked",'2');//设置value=2的项目为当前选中项
下拉框select: $("#sel").attr("value",'-sel3');//设置value=-sel3的项目为当前选中项
$("<option value='1'>1111</option><option value='2'>2222</option>").appendTo("#sel")//添加下拉框的option
$("#sel").empty();//清空下拉框

 

 

==========================

 

<body>
<button>Click Here</button>
<div>this is a div</div>
<p>this is a p</p>
<span>this is a span</span><br /><br />
<b>this is a b</b><br /><br />
<em>this is a em</em>
</body>

 $(function(){

    $("button").click(
    function(){
    var a1="";
    var a2="";
    var a3="";
    var a4="";
    var a5="";
    var colors=['red','blue','green','yellow','black','white','orange'];
    var color_ary=[{'id':'red','code':'01'},{'id':'blue','code':'02'},{'id':'green','code':'03'},{'id':'yellow','code':'04'},
             {'id':'black','code':'05'},{'id':'white','code':'06'},{'id':'orange','code':'07'}];

      $.each(colors,function(item){a1+=item+",";});
      //each方法中的函数参数为一个时,此参数为遍历的索引值,同for循环的 i 变量。
      $.each(colors,function(index,item){a2+=item[index]+",";});
      //each方法中的函数参数为两个时,item为数组的每一项,item[index]返回的是对item对象的提取。
      $.each(colors,function(index,item){a3+=item+",";});    
      //item为数组的每一项,如此可正常的显示数组,同样的color[index]也可正常的显示数组。
      $.each(color_ary,function(index,item){a4+=item.id+":"+item.code+",";});
      //当数据为json格式时,可以如此来解析此json
      $.each(color_ary,function(index,item){a5+=color_ary[index].id+":"+color_ary[index].code+",";});
      //当数据为json格式时,也可以如此来解析此json
    
      $("div").text(a1);
      $("p").text(a2);
      $("span").text(a3);
      $("b").text(a4);
      $("em").text(a5)
      })
})

 

 

======================================

 

 

jquery 中json数组的操作

在jquery中处理JSON数组的情况中遍历用到的比较多,但是用添加移除这些好像不是太多。

今天试过json[i].remove(),json.remove(i)之后都不行,看网页的DOM对象中好像JSON数据是以数组的形式出现的,查阅了下相关JS中数组的操作一试果然很爽。

记录下来。

1、数组的创建

var arrayObj = new Array(); //创建一个数组

var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限,是长度

var arrayObj = new Array([element0[, element1[, ...[, elementN]]]]); 创建一个数组并赋值

    要说明的是,虽然第二种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。

2、数组的元素的访问

var testGetArrValue=arrayObj[1]; //获取数组的元素值

arrayObj[1]= "这是新值"; //给数组元素赋予新的值

3、数组元素的添加

arrayObj. push([item1 [item2 [. . . [itemN ]]]]);// 将一个或多个新元素添加到数组结尾,并返回数组新长度

arrayObj.unshift([item1 [item2 [. . . [itemN ]]]]);// 将一个或多个新元素添加到数组开始,数组中的元素自动后移,返回数组新长度

arrayObj.splice(insertPos,0,[item1[, item2[, . . . [,itemN]]]]);//将一个或多个新元素插入到数组的指定位置,插入位置的元素自动后移,返回""。

4、数组元素的删除

arrayObj.pop(); //移除最后一个元素并返回该元素值

arrayObj.shift(); //移除最前一个元素并返回该元素值,数组中元素自动前移

arrayObj.splice(deletePos,deleteCount); //删除从指定位置deletePos开始的指定数量deleteCount的元素,数组形式返回所移除的元素

5、数组的截取和合并

arrayObj.slice(start, [end]); //以数组的形式返回数组的一部分,注意不包括 end 对应的元素,如果省略 end 将复制 start 之后的所有元素

arrayObj.concat([item1[, item2[, . . . [,itemN]]]]); //将多个数组(也可以是字符串,或者是数组和字符串的混合)连接为一个数组,返回连接好的新的数组

6、数组的拷贝

arrayObj.slice(0); //返回数组的拷贝数组,注意是一个新的数组,不是指向

arrayObj.concat(); //返回数组的拷贝数组,注意是一个新的数组,不是指向

7、数组元素的排序

arrayObj.reverse(); //反转元素(最前的排到最后、最后的排到最前),返回数组地址

arrayObj.sort(); //对数组元素排序,返回数组地址

8、数组元素的字符串化

arrayObj.join(separator); //返回字符串,这个字符串将数组的每一个元素值连接在一起,中间用 separator 隔开。

toLocaleString 、toString 、valueOf:可以看作是join的特殊用法,不常用

 

 

 

分享到:
评论

相关推荐

    jQuery为动态生成的select元素添加事件的方法

    6. 动态添加元素到页面中:在需要的时候,使用jQuery的`.append()`方法将创建好的select元素添加到页面的指定容器中。这个操作会把新的HTML字符串插入到页面的DOM中,从而使得select元素变得可用。 7. 绑定事件到...

    jquery 动态遍历select 赋值的实例

    本文主要讲解了如何使用jQuery动态地遍历select元素,并为其赋值。这是一项非常实用的技术,尤其在动态网站开发中,经常会遇到需要根据不同的数据动态更新下拉列表选项的情况。 知识点一:遍历和选择select元素中的...

    jquery动态加载select下拉框示例代码

    本文档将介绍如何使用jQuery库来动态加载select下拉框选项。jQuery是一个快速、小型且功能丰富的JavaScript库,它通过简化HTML文档遍历、事件处理、动画和Ajax交互,使得Web开发更加便捷。 **知识点一:jQuery动态...

    Jquery combo-select

    2. 静态数据与动态加载:对于大量数据,可以考虑在用户输入时异步加载匹配的选项,以提高页面性能。 3. 错误处理:添加验证机制,防止用户输入非法值。 4. 多选模式:支持多选功能,用户可以同时选择多个选项。 5...

    jQuery手机下拉框select

    - **`.selectmenu('refresh')`方法**:当DOM元素被动态添加或修改后,调用此方法可以重新渲染Select Menu。 ### 示例代码 ```html &lt;select id="mySelect" data-role="select"&gt; &lt;option value="option1"&gt;Option 1 ...

    JQuery动态添加Select的Option元素实现方法

    如下所示: var selector=$('&lt;select&gt;&lt;/select&gt;...以上这篇JQuery动态添加Select的Option元素实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持软件开发网。

    jQuery-ComboSelect插件

    此外,插件可能还需要与后端进行交互,例如动态加载选项数据。开发者可以通过Ajax请求获取数据,然后使用插件的API方法更新下拉列表,确保用户看到的是最新、最完整的选项。 需要注意的是,尽管jQuery-ComboSelect...

    JS & JQuery 动态添加 select option

    ### JS & JQuery 动态添加 select option 知识点总结 #### 1. JavaScript 动态添加 option JavaScript中动态添加option到select元素主要使用`document.getElementById`获取select元素,然后利用其`options`属性...

    jQuery实现动态加载select下拉列表项功能示例

    在本文中,我们将探讨如何使用jQuery来实现动态加载select下拉列表项的功能。这是一个非常实用的技术,特别是在网页应用中,当需要根据用户的选择或者特定条件动态更新下拉选项时。 **需求说明:** 传统的select...

    jquery.editable-select

    通过以上知识点,我们可以看出 `jquery.editable-select` 是一个强大且灵活的工具,能够显著提升用户在选择操作中的体验,尤其适合需要动态过滤和自定义输入的场景。正确地理解和运用这些知识点,将使你在实际项目中...

    jquery动态生成select工作日列表Workday

    在这个特定的项目中,“jquery动态生成select工作日列表Workday”是利用jQuery来实现一个功能,该功能可以动态地创建一个SELECT元素,并填充每月周一至周五的工作日日期。 首先,我们需要理解“select”元素在HTML...

    jquery select2组件

    - **自定义数据源**:除了绑定HTML `&lt;option&gt;`元素,`Select2`还能从JSON或其他数据源动态加载选项。 - **分组选项**:通过在`&lt;optgroup&gt;`标签内添加`&lt;option&gt;`,可以实现选项的分组展示。 - **自定义模板**:你可以...

    jquery 动态select实现

    然而,静态的`select`在某些场景下可能无法满足需求,比如当选项需要根据用户的其他操作或数据动态更新时,我们就需要借助jQuery来实现动态加载。 在jQuery中,动态创建或修改`select`元素的基本步骤包括: 1. **...

    jquery select动态加载选择(兼容各种浏览器)

    针对这个问题,标题提到的"jquery select动态加载选择(兼容各种浏览器)"提供了一个解决方案,即`set_select_val`函数,它专门用于在IE6下正确地为`&lt;select&gt;`元素设置值。 通常,在大部分现代浏览器中,我们可以通过...

    动态加载select标签下拉框数据

    动态加载select下拉框数据不仅适用于Web应用,也适用于移动应用。它有助于减少网络带宽消耗,加快页面响应速度,并允许用户更快地找到他们想要的选项,是现代Web开发中不可或缺的一个技巧。了解和掌握这项技术对于...

    JQuery版的select下拉效果

    为了提升用户体验,开发者们常常会借助于第三方库,如jQuery,来实现更加丰富和动态的下拉选择效果。 JQuery是一个广泛使用的JavaScript库,它简化了DOM操作、事件处理、动画制作等任务。在本项目中,`jquery....

    jquery实现select带模糊搜索下拉选择框

    如果你需要替换下拉内容,可以在页面加载完成后,动态添加 `option` 元素。例如: ```javascript $(document).ready(function() { var options = [ { value: 'option1', text: 'Option 1' }, { value: 'option...

    关于jquery中动态增加select,事件无效的快速解决方法

    近来做项目,用的jquery1.6.2库,当动态增加div 及select时,事件却不起作用。 查了一些资料,发现bind事件:向匹配元素附加一个或更多事件处理器。而live事件:为当前或未来的匹配元素添加一个或多个事件处理器。 ...

Global site tag (gtag.js) - Google Analytics