ajax 三级联动商品分类(转载)
转载
自 jines http://www.cnblogs.com/lijinblogs/p/5759399.html
思路分析:
效果:当页面加载时,利用ajax异步向后台请求数据,加载一级商品类别,当选择一级商品时加载二级商品,选择二级商品加载三级商品。
实现:
1、当拿到数据后加载pid为0的商品,并动态创建option将商品追加到一级菜单中,并设置value值
2、当选择一级商品时加载pid=当前id的商品,并创建option将商品追加到二级菜单中,并设置value值
3、当选择二级商品时加载pid=当前id的商品,并创建option将商品追加到三级菜单中,并设置value值
页面效果:


1 $(function(){
2 //请求路径
3 var url="03goods.php";
4 //option默认内容
5 var option="<option value='0'>未选择</option>";
6 //获取jq对象
7 var $sel1=$(".sel1");
8 var $sel2=$(".sel2");
9 var $sel3=$(".sel3");
10 //自动生成一个<option>元素
11 function createOption(value,text){
12 var $option=$("<option></option>");
13 $option.attr("value",value);
14 $option.text(text);
15 return $option;
16 }
17 //加载数据
18 function ajaxSelect($select,id){
19 //get请求
20 $.get(url,{"pid":id},function(data){
21 $select.html(option);
22 for(var k in data ){
23 $select.append(createOption(data[k].id,data[k].name));
24 }
25 },"json");
26 }
27
28 //自动加载第一个下拉菜单
29 ajaxSelect($sel1,"0");
30
31 //选择第一个下拉菜单时加载第二个
32 $sel1.change(function(){
33 var id=$sel1.val();
34 if(id=="0"){
35 $sel2.html(option);
36 $sel3.html(option);
37 }else{
38 ajaxSelect($sel2,id);
39 }
40 });
41
42 //选择第二个下拉菜单时加载第三个
43 $sel2.change(function(){
44 var $id=$sel2.val();
45 if($id=="0"){
46 $sel3.html(option);
47 }else{
48 ajaxSelect($sel3,$id);
49 }
50 });
51 });

后台代码:

1 <?php
2 header('Content-Type:text/html; charset=utf-8');
3 //数据
4 $arr=array(
5 //array(分类id,分类名,分类的父id)
6 array('id'=>'1','name'=>'数码产品','pid'=>'0'),
7 array('id'=>'2','name'=>'家电','pid'=>'0'),
8 array('id'=>'3','name'=>'书籍','pid'=>'0'),
9 array('id'=>'4','name'=>'服装','pid'=>'0'),
10 array('id'=>'5','name'=>'手机','pid'=>'1'),
11 array('id'=>'6','name'=>'笔记本','pid'=>'1'),
12 array('id'=>'7','name'=>'平板电脑','pid'=>'1'),
13 array('id'=>'8','name'=>'智能手机','pid'=>'5'),
14 array('id'=>'9','name'=>'功能机','pid'=>'5'),
15 array('id'=>'10','name'=>'电视机','pid'=>'2'),
16 array('id'=>'11','name'=>'电冰箱','pid'=>'2'),
17 array('id'=>'12','name'=>'智能电视','pid'=>'10'),
18 array('id'=>'13','name'=>'编程书籍','pid'=>'3'),
19 array('id'=>'14','name'=>'JavaScript','pid'=>'13'),
20 );
21 //获取指定分类的商品
22 function getByPid($arr,$pid){
23 $result=array();
24 foreach($arr as $v){
25 if($v['pid']==$pid){
26 $result[]=$v;
27 }
28 }
29 return $result;
30 }
31 //获取请求参数
32 $pid=isset($_GET['pid'])?$_GET['pid']:'0';
33
34 $result=getByPid($arr,$pid);
35 //输出json数据
36 echo json_encode($result);
37 ?>

ajax 三级联动商品分类(转载)的更多相关文章
- ajax验证表单元素规范正确与否 ajax展示加载数据库数据 ajax三级联动
一.ajax验证表单元素规范正确与否 以用ajax来验证用户名是否被占用为例 1创建表单元素<input type="text" id="t"> 2 ...
- 使用 AJAX + 三级联动 实现分类出全国各地的省,市,区
使用AJAX + 三级联动 实现分类出全国各地的省,市,区 也可以将下面的显示页面所写的 function循环,封装成js文件,就是在写代码软件里创建一个js文件,就和创建一个HTML或php文件一 ...
- AJAX 三级联动
新的封装类 <?php class DBDA { public $host="localhost";//服务器地址 public $uid="root"; ...
- ajax三级联动下拉菜单
ajax写三级联动,先写一个文件类吧,以后用的时候直接调用即可: 来找一张表: 实现: 中国地域的三级联动:省.市.区: 图: 说一下思路: (1)当用户选择省份的时候触发事件,把当前的省份的id通过 ...
- 0509 关于Ajax + 三级联动示例
关于Ajax 1.干什么的? ajax负责抓取用户名信息,传递给服务器进行校验: 2.属性: onreadystatechange:事件,该事件可以感知ajax状态(readyState)的变化.aj ...
- [Ajax三级联动 无刷新]
三级联动 的效果图 html页面: <body> <label class="fl">区域:</label> <select class= ...
- 2019.03.25 Ajax三级联动
所谓三级联动就是,一层接着一层,根据上一层的选择给出这一层的结果 如选择市之后,会给出相应的区,然后到相应的县这就是联动 配置视图 from django.core import serialize ...
- Ajax三级联动
全国省市县查询 html代码 <!doctype html> <html> <head> <meta charset="utf-8"> ...
- 原生javascript AJAX 三级联动
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- 07.重写ToSting()方法
namespace _08.重写ToString方法 { class Program { static void Main(string[] args) { Person p = new Person ...
- 基于bootstrap的图片轮播功能
插入js及css支持: <link rel="stylesheet" href="css/bootstrap.min.css"/> <scri ...
- Linux From Scratch(从零开始构建Linux系统,简称LFS)(二)
七. 构建临时系统 1. 通用编译指南 a. 确认是否正确设置了 LFS 环境变量 echo $LFS b. 假定你已经正确地设置了宿主系统需求和符号链接 c. 对于每个软件包: (1). 确保解压软 ...
- flask-login的简单实用
# encoding: utf-8 from flask import Flask, Blueprint from flask_login import (LoginManager, login_re ...
- filter() 方法创建一个新数组
filter快速过滤创建一个新数组 var new_array = arr.filter(callback(element[, index[, array]])[, thisArg]) 参数节 cal ...
- Perl学习笔记(3)----遍历哈希表的一个容易疏忽的地方
今天做 Google的 Code Jam 上的一道题目:https://code.google.com/codejam/contest/351101/dashboard#s=p2,用Perl语言解答的 ...
- dialog problem overview
一 Datasets 1. ubuntu chat corpus: http://daviduthus.org/UCC/2. dialogue datasets (circa 2005) 二 Tas ...
- myeclipse 下载 checkstyle 引入后不显示问题
参照这篇博客,http://blog.csdn.net/zzq900503/article/details/42003499 下载最新的checkstyle版本后,在本地导入后一直不显示,步骤什么的也 ...
- c# 依赖注入之---反射(转)
详细请看http://www.cnblogs.com/leoo2sk/archive/2009/06/17/1504693.html 定义一个接口,和两个类(实现该接口) IButton: using ...
- linux 文件常用操作
linux 文件基本操作 新建文件:touch test 不会替换重名文件,并且linux一切都是文件,文件夹和文件不能重名 新建文件夹:mkdir test使用 -p 参数,同时创建父目录(如果不存 ...