jquery select2 联动下拉列表赋值二级下拉列表赋不上值,怎么搞
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jquery select2 联动下拉列表赋值二级下拉列表赋不上值,怎么搞相关的知识,希望对你有一定的参考价值。
参考技术A 你是怎么搞的,代码贴出来看看。二级联动,都是在一级上加一个onchange事件,触发时更新二级就可以了。
<selelct id="sel1" onchange="changeData()"></selelct>
<selelct id="sel2"></selelct>
function changeData()
var v = $("#sel1").val();
$("#sel2").html('<option>........</option>');
追问
我是页面上有个编辑的弹出框是个层,点编辑后弹出来,上面有两个联动的下拉列表,现在是弹出后 一级下来列表可以赋值,但是二级的赋不到默认值,下拉列表信息是可以出来的 就是没有选中该选的项。
追答代码,你的代码贴出来,我才能看是什么原因
追问ajaxCallback(true, baseurl + "/ReportHandler.ashx?t=102”, data, function (d)
先绑定下拉列表,再赋值,字数超限了贴不出来
$("#A").select2("val", bugroup);
);
$("#A").select2("val", bugroup);
这个写法不知道是什么组件的,看不懂
一般的给select赋值。
$("#selectID").val('值');
jQuery+PHP+MySQL实现二级联动下拉菜单
二级联动下拉菜单选择应用在在很多地方,比如说省市下拉联动,商品大小类下拉选择联动。本文将通过实例讲解使用jQuery+PHP+MySQL来实现大小分类二级下拉联动效果。
先看下效果
实现的效果就是当选择大类时,小类下拉框里的选项内容也随着改变。实现原理:根据大类的值,通过jQuery把值传给后台PHP处理,PHP通过查询MySQl数据库,得到相应的小类,并返回JSON数据给前端处理。
XHTML
首先我们要建立两个下拉选择框,第一个是大类,第二个是小类。大类的值可以是预先写好,也可以是从数据库读取。
<label>大类:</label>
<select name="bigname" id="bigname">
<option value="1">前端技术</option>
<option value="2">程序开发</option>
<option value="3">数据库</option>
</select>
<label>小类:</label>
<select name="smallname" id="smallname">
</select>
jQuery
先写一个函数,获取大类选择框的值,并通过$.getJSON方法传递给后台server.php,读取后台返回的JSON数据,并通过$.each方法遍历JSON数据,将对应的值写入一个option字符串,最后将option追加到小类里。
function getSelectVal(){
$.getJSON("server.php",{bigname:$("#bigname").val()},function(json){
var smallname = $("#smallname");
$("option",smallname).remove(); //清空原有的选项
$.each(json,function(index,array){
var option = "<option value='"+array['id']+"'>"+array['title']+"</option>";
smallname.append(option);
});
});
}
注意,在遍历JSON数据追加之前一定要先将小类里的原有的项清空。清空选项的方法有两种,一种是上文代码中提到,还有一种更简单直接的方法:
smallname.empty();
然后,在页面载入后执行调用函数:
$(function(){
getSelectVal();
$("#bigname").change(function(){
getSelectVal();
});
});
在页面初始的时候,下拉框是要设置选项的,所以在初始的时候就要调用getSelectVal(),而当大类选项改变时,也调用了getSelectVal()。
PHP
include_once("connect.php"); //链接数据库
$bigid = $_GET["bigname"];
if(isset($bigid)){
$q=mysql_query("select * from catalog where cid = $bigid");
while($row=mysql_fetch_array($q)){
$select[] = array("id"=>$row[id],"title"=>$row[title]);
}
echo json_encode($select);
}
根据jQuery传递过来的大类的value值,构造SQL语句查询分类表,最终输出JSON数据。本站在未做特别说明的情况下所使用的PHP与MySQL连接,和查询语句等均使用原始语句方法如mysql_query等,目的就是为了让读者能够直观的知晓数据的传输查询。
最后附上MYSQL表结构:
CREATE TABLE `catalog` (
`id` mediumint(6) NOT NULL auto_increment,
`cid` mediumint(6) NOT NULL default '0',
`title` varchar(50) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
以上是关于jquery select2 联动下拉列表赋值二级下拉列表赋不上值,怎么搞的主要内容,如果未能解决你的问题,请参考以下文章