Jquery Ajax无刷新加载select值代码

JS部分*******/

T//此处调用prototype.js包,$("aa") 相当于 document.getElementById("aa");
 
//js部分。首先调用prototype的ajax应用

 代码如下 复制代码
 
function getSelectArr(id,type)
{
    var url = '/action.php';                                     //php页面
    var pars = "type=" + type + "&id=" + id;          //参数拼接
    //post方式提交,并执行回调函数‘createSelect’
 
    var ajax=new Ajax.Request(url,{method:'post',parameters:pars,onComplete:createSelecet});
}
 
function createSelecet(info)
{
    //Json串,ajax的返回值。
    //原型die(json_encode(array(array($text,$value),array($text2,$value2)));)
    var arr = eval(info.responseText);  
    //创建select元素
    var select = document.createElement("select");
    //给select添加属性
    select.setAttribute("name","commu_album_id");      
    for(var i=0; i < arr.length; i++){
    //给select添加option
    select.options.add(new Option(arr[i][0],arr[i][1]));    
 
    $("target_commu_album_id").innserHTML ="";
    //将select添加到某标签中
    $("target_commu_album_id").appendChild(select);    
}

/*************php部分*******/

php部分主要接收 id 和 type

 代码如下 复制代码
T$id = $_REQUEST['id'];
 
$type = $_REQUEST['type'];

然后查询要显示在select框中的信息,并按照顺序,比如 array(option值,optionText)放到一个数组中。然后json转换成json传输出或者放在die()中,js就可以接收了。

比如 执行

 代码如下 复制代码
Tdie(
 
json_encode(
 
array(
 
array(1,"招生部"),
 
array(2,"财务部"),
 
array(3,"行政部"),
 
)));

注意:数组中只放值,不要加键。

如此在js的createSelect(info)中

 代码如下 复制代码
var arr = eval(info.responseText);

arr就是个数组, arr[0][0] = 1,arr[0][1]=”招生部” 。

 代码如下 复制代码

arr[1][0] = 2,arr[1][1]=”财务部”

另一种办法,如果你常用上面麻烦我们可以使用全js联动菜单效果

超简单的js二级联动菜单

 代码如下 复制代码
<script language="javascript">
 subcat = new Array();
 subcat[0] = new Array("测试门店","1","1");subcat[1] = new Array("江西荣裕药业集团有限公司","1","2"); 
 var onecount=2;
function changelocation(locationid)
    {
    document.registerform.cityareaid.length = 1;
    var locationid=locationid;
    var i;
 var nindex;
    for (i=0;i < onecount; i++)
        {
            if (subcat[i][1] == locationid)
            {
             document.registerform.cityareaid.options[document.registerform.cityareaid.length] = new Option(subcat[i][0], subcat[i][2]);
   
            }       
        }
  
    } 
function doChange(objText, objDrop){
  if (!objDrop) return;
  var str = objText.value;
  var arr = str.split("|");
  var nIndex = objDrop.selectedIndex;
  objDrop.length=1;
  for (var i=0; i<arr.length; i++){
   objDrop.options[objDrop.length] = new Option(arr[i], arr[i]);
  }
  objDrop.selectedIndex = nIndex;
}
</script>
<form name="registerform" id="registerform" method="POST" action="">
<select name="cityid" id="cityid"  onblur="changelocation(document.registerform.cityid.options[document.registerform.cityid.selectedIndex].value)">
    <option value="">--不限城市--</option>
    <option value=1> test www.111cn.net</option>    </select>
    
    <select  name="cityareaid"   id="cityareaid">
    
      <option value="0">--不限区域--</option>
     
    </select> 
   </form>
时间: 2024-11-10 09:39:13

Jquery Ajax无刷新加载select值代码的相关文章

js ajax无刷新加载页面程序代码

js原生态写法  代码如下 复制代码 var mm;   var nn;   function makeRequest(url,obj,b) {   mm=obj;   nn=b;    http_request = false;    if (window.XMLHttpRequest) {     http_request = new XMLHttpRequest();     if (http_request.overrideMimeType){      http_request.ove

asp.net点击 查看更多 实现无刷新加载的实现代码_实用技巧

页面页面的js代码如下, 复制代码 代码如下: <script type="text/javascript"> $(function () { function init(count, start) { $.ajax({ type: "GET", dataType: "json", url: "Handler/Handler.ashx", data: { action: "GetMoreNews"

使用Yii整合的pjax(pushstate+ajax)实现无刷新加载页面_AJAX相关

Pjax是啥? Pjax = history.pushState + Ajax = history.pushState + Async JS + XML(xhr?) BOM对象history被增强了一波,主要是对历史栈的操作,以前只有 replace , go 之类的,都会跳转并刷新整个页面,现在有了 pushState , replaceState 等等单纯操作历史栈的方法,只是单纯修改历史栈里的内容,没有副作用(页面不会跳转刷新) PJAX效果 通过url可以跟踪ajax的动态加载内容.这种

使用Yii整合的pjax(pushstate+ajax)实现无刷新加载页面

Pjax是啥? Pjax = history.pushState + Ajax = history.pushState + Async JS + XML(xhr?) BOM对象history被增强了一波,主要是对历史栈的操作,以前只有 replace , go 之类的,都会跳转并刷新整个页面,现在有了 pushState , replaceState 等等单纯操作历史栈的方法,只是单纯修改历史栈里的内容,没有副作用(页面不会跳转刷新) PJAX效果 通过url可以跟踪ajax的动态加载内容.这种

jquery实现界面无刷新加载登陆注册_jquery

官网的登陆注册每次要跳转到另一个界面,能不能做一个简单的,在界面弹出一个框框登陆,我想了想做了这么一个案例,大家来看看成不成 贴上代码,实现了在同一个弹出窗上加载了登陆注册功能!可自由点击!当然样式丑了一些!还请见谅!demo在下面 1这里是html内容 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transi

jquery AJAX无刷新评论实例

<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="content-

jQuery Ajax页面局部加载方法汇总_jquery

在jquery中实现ajax加载的方法有很多种,不像以前的js的ajax只有那一种,下面我们介绍jquery ajax实现局部加载方法总结,有需要了解的朋友可参考. 例 $.ajax({ url: "hotelQuery!queryHotelByCity.action", type: "post", dataType: "html", data: "queryHotel.city="+cityobj.value+"&

js-点击A页面链接,B页面无刷新加载内容

问题描述 点击A页面链接,B页面无刷新加载内容 比如百度音乐,在A页面不管点击多少个音乐,都只打开一个B页面并且无刷新加载播放.怎么用JS和其它编程语言来实现? 解决方案 <a target='musicBox' href=""/music"">播放1</a><a target='musicBox' href=""/music"">播放2</a><a target='mus

jquery+ajax 使用.load()加载的页面一闪一闪的

问题描述 jquery+ajax 使用.load()加载的页面一闪一闪的 问题页面www.361goal.com 刚开始打开的页面使用load成功加载了ajax页面,但是点击标签"彩票"以后,使用load()加载同样的页面,就会出现一闪一闪的现象,如图所示 这是为什么呢? 我的"彩票"标签按钮绑定的时间函数是: function loadData(n) { //$("#matchList").empty(); $.ajaxSetup({ cach