<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<select >
<option value="">品牌</option>
<option value="">宝马</option>
<option value="">奔驰</option>
</select>
<select > <option value="">车型</option>
<option value="">520LI</option>
</select>
<select > <option value="">车款</option>
<option value="">2016 1.8T</option>
</select> </body>
<script src="js/make_json.js" type="text/javascript" charset="utf-8"></script>
<script src="js/model_json.js" type="text/javascript" charset="utf-8"></script>
<script src="js/car_json.js" type="text/javascript" charset="utf-8"></script>
<script src="js/jquery-1.7.2.min.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
var car_json ={
5001: [{
name: "1.8 TSI 2012-2014",
pinyin: "",
id: 129643
}],
5002: [{
name: "2.0 TSI 2012-2014",
pinyin: "",
id: 129176
}]
};

var make_json = {
aodi: {
name: "奥迪",
id: 272
},
baoma: {
name: "宝马",
id: 270
} }
var model_json = {
201: [{
name: "Leon Cupra",
pinyin: "",
id: 5002
}, {
name: "Leon FR",
pinyin: "",
id: 5001
}]
}
      //0. 获取元素

      var selects = $('select');

      //品牌
var make = selects.eq(0); //车型
var model = selects.eq(1); //车款
var car = selects.eq(2); //1.遍历生成品牌列表 var html = ''; $.each(make_json,function(i){ //2.将品牌信息拼接成html html+='<option value="'+this.id+'">'+this.name+'</option>'; }) //3.更新品牌列表 make.children(':not(:first)').remove(); make.append(html); //4.添加品牌change事件 make.change(function(){ //5.获取当前的品牌ID var id = this.value; //6. 根据品牌ID获取当前品牌下的车型数据 var modelData = model_json[id] || [] ; //7.遍历车型 数据生成车型 列表 var html = ''; $.each(modelData,function(i){ //8.将车型信息拼接成html html+='<option value="'+this.id+'">'+this.name+'</option>'; }) //9.更新车型列表 model.children(':not(:first)').remove(); model.append(html); //9.1 设置默认被选中车型 获取车型 中的第二个选项 model.children(':eq(1)').attr('selected',true); //9.2根据当前被选中的车型 获取对应的车款信息 var id = model.val(); //6. 根据车型ID获取当前品牌下的车款数据 var carData = car_json[id] || [] ; //7.遍历车型 数据生成车型 列表 var html = ''; $.each(carData,function(i){ //8.将车型信息拼接成html html+='<option value="'+this.id+'">'+this.name+'</option>'; }) //9.更新车型列表 car.children(':not(:first)').remove(); car.append(html); car.children(':eq(1)').attr('selected',true);
}) //10.车型change事件 model.change(function(){ //11.获取当前的车型ID var id = this.value; //6. 根据车型ID获取当前品牌下的车款数据 var carData = car_json[id] || [] ; //7.遍历车型 数据生成车型 列表 var html = ''; $.each(carData,function(i){ //8.将车型信息拼接成html html+='<option value="'+this.id+'">'+this.name+'</option>'; }) //9.更新车型列表 car.children(':not(:first)').remove(); car.append(html);
car.children(':eq(1)').attr('selected',true);
}) </script>
</html>

js三级联动的更多相关文章

  1. 省市区js三级联动(原创)

    看了一些网上的js三级联动,但感觉不是缺这,就是少那,决定亲自操刀写了一个,现记录如下,以备后用! <!DOCTYPE html> <html> <head> &l ...

  2. js 三级联动

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...

  3. js 三级联动 1

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  4. 简单的纯js三级联动

    参考这个  日尼禾尔  二级联动 写了三级联动 <!DOCTYPE html> <html> <head> <meta charset="UTF-8 ...

  5. 原生js三级联动

    <!DOCTYPE html> <html lang="en"> <head> <title> 三级联动 </title> ...

  6. Js三级联动菜单

    效果演示: <SCRIPT LANGUAGE="JavaScript"> <!-- function CreateSelect(_FormName,_SName, ...

  7. JS三级联动实例

    简单的HTML实例: <h4>选择省</h4> <div class="selectSheng"></div> <select ...

  8. js三级联动效果city-picker

    链接:https://pan.baidu.com/s/1NE_EO5_xGvR-y-lboYap7g 提取码:h00e 效果展示: 解决: 动态赋值: 注意:在执行赋值之前,必须执行reset和des ...

  9. 三级联动第二种方法 三级联动.html

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

随机推荐

  1. Appium 坑

    1. [Android]click没有反应 https://testerhome.com/topics/9610 在某些手机上有个安全选项,需要在开发者选项->安全设置(允许模拟点击),打开开关

  2. ubuntu , 安装包的具体文件的查看方法

    To see all the files the package installed onto your system, do this: dpkg-query -L <package_name ...

  3. 微信公众号菜单添加小程序,miniprogram,pagepath参数详解,php开发公众号

    随着微信小程序功能的开发, 已经可以跟公众号打通了, 主要有两种方式: 1) 在公众号文章中插入小程序 2) 在公众号菜单中添加小程序 第一种方式, 子恒老师在前面的课程已经详细介绍过, 今天来讲第二 ...

  4. Spring Cloud常用组件介绍

    一.Eureka (Netfix下) 云端服务发现,一个基于 REST 的服务,用于定位服务,以实现云端中间层服务发现和故障转移. 二.Spring Cloud Config (Spring下) 配置 ...

  5. memcached哈希表操作主要逻辑笔记

    以下注释的源代码都在memcached项目的assoc.c文件中 /* how many powers of 2's worth of buckets we use */ unsigned int h ...

  6. android--------微信 Tinker 热修复 (二)

    前面简单介绍了一下Tinker热修复,今天就来分享一下如何在Android中使用,希望对各位有帮助. 1:Tinker 接入指南 在项目的build.gradle中,添加tinker-patch-gr ...

  7. 根据条件设置poplist的值集

    需求:在当前页面的pageButtonBar中有一个下拉选择框,选择框中的值集根据某些条件有不同. public class SupplierInfoReviewCO extends OAContro ...

  8. Python简单网页爬虫——极客学院视频自动下载

    http://blog.csdn.net/supercooly/article/details/51003921

  9. 通过url获取参数信息

    运行结果如下: <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <ti ...

  10. 快速切题 sgu116. Index of super-prime bfs+树思想

    116. Index of super-prime time limit per test: 0.25 sec. memory limit per test: 4096 KB Let P1, P2, ...