使用ajax+jqtransform实现动态加载select
使用ajax+jqtransform实现动态加载select
发布时间:2016-12-30 来源:查字典编辑
摘要:今天在工作的时候遇到一个问题,页面中公司名称是在项目名称选择后用ajax读取出来的。但是jqtransform是在页面加载完成后调用的,所以...

今天在工作的时候遇到一个问题,页面中公司名称是在项目名称选择后用ajax读取出来的。但是jqtransform是在页面加载完成后调用的,所以导致了公司名称下拉框无法展示最新的数据。

<link rel="stylesheet" href="${ctx}/jqtransformplugin/jqtransform.css" type="text/css"></link>

<script type="text/javascript" src="${ctx}/jqtransformplugin/jquery.jqtransform.js"></script>

<SCRIPT type="text/javascript">

$(function(){

$('form').jqTransform({imgPath:'images/JQueryformimg/'});

});

</SCRIPT>

使用ajax+jqtransform实现动态加载select1

使用ajax+jqtransform实现动态加载select2

使用ajax+jqtransform实现动态加载select3

用firebug可以看到数据其实已经拼接上去了,但是form已经在页面加载后已经调用过jqTransform方法, jqTransformSelectWrapper里面的ul数据没有更新。想了许久决定用简单粗暴的方法把ul更新掉。

function companyAjax(proid){

$.ajax({

type:"POST",

url:"${pageContext.request.contextPath}/recordsearch/ajax/getCompanyAjax.do",

dataType:"json",

data:{proid : proid},

success:function(jsondata){

var tmp='';

tmp+='<select id="centerid" name="centerid" onchange="comChange()" name="centerid">';

//$("#centerid").empty(); tmp+='<option value="">--请选择--</option>';

for(var i=0;i<jsondata.length;i++){

tmp+='<option value="'+jsondata[i].centerid+'">'+jsondata[i].centername+'</option>';

}

tmp+='</select>';

$("#centerid").parent().remove();

$("#comLable").after(tmp);

$("#centerid").jqTransSelect();

}

});

}

哈哈,在ajax查询公司数据之后,将jqtransform生成的select相关的div删除掉,然后把selct拼接上,再重新初始化select。方法比较蠢,不过先用着吧,以后有更好的办法再说。

使用ajax+jqtransform实现动态加载select4

是不是很炫酷。。哈哈,其实还是jqtransform比较给力,小伙伴们以后需要使用类似效果的话,可以参考下。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类