Django Web实现动态三级联动

1.平台环境

    操作系统:Windows 7 64位

    开发环境:Eclipse PyDev


2.文件夹结构

    直接看下面的图片:

    目前很多文件还用不上,在创建Django的项目时或app时,很多文件都是自动生成的,下面会说一说可以用得上的文件。


3.主要功能文件与代码

(1)MapPro/settings.py

    目前主要是用来设置statics和templates,告诉Django这两个目录的存在路径,添加的代码如下:


1

2

3

4

5

6

7

TEMPLATE_DIRS = (

                 os.path.join(BASE_DIR,'templates'),

                 )

 

STATICFILES_DIRS = (

                    os.path.join(BASE_DIR,'statics'),

                    )

(2)MapPro/urls.py

    设置url路径和views视图函数的映射关系,全部代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

from django.conf.urls import patterns, include, url

from django.contrib import admin

from app01 import views

 

urlpatterns = patterns('',

    # Examples:

    # url(r'^$', 'MapPro.views.home', name='home'),

    # url(r'^blog/', include('blog.urls')),

 

    url(r'^admin/', include(admin.site.urls)),

    url(r'^map/$',views.Map),

    (r'^GetCityData/$',views.Return_City_Data),

    (r'^GetCountryData/$',views.Return_Country_Data),

)

(3)app01/views.py

    视图函数文件,用来处理业务逻辑,全部代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

from django.shortcuts import render,render_to_response

from django.http import HttpResponse

from django.core.context_processors import request

import json

 

# Create your views here.

 

def Map(request):

    return render_to_response("map.html")

    #return HttpResponse("Hello!")

     

Place_dict = {

        "GuangDong":{

                        "GuangZhou":["PanYu","HuangPu","TianHe"],

                        "QingYuan":["QingCheng","YingDe","LianShan"],

                        "FoShan":["NanHai","ShunDe","SanShui"]

                        },

        "ShanDong":{

                        "JiNan":["LiXia","ShiZhong","TianQiao"],

                        "QingDao":["ShiNan","HuangDao","JiaoZhou"]

                        },

        "HuNan":{

                        "ChangSha":["KaiFu","YuHua","WangCheng"],

                        "ChenZhou":["BeiHu","SuXian","YongXian"]

                    }

    };

def Return_City_Data(request):

    province = request.GET['Province']

    print province

    City_list = []

    for city in Place_dict[province]:

        City_list.append(city)

    return HttpResponse(json.dumps(City_list))    

     

def Return_Country_Data(request):

    province,city = request.GET['Province'],request.GET['City']

    print province,city

    Country_list = Place_dict[province][city]

    return HttpResponse(json.dumps(Country_list))

    这里的代码比较简单,就不写注释了。

(4)templates/map.html

    templates目录主要用来放置页面的模板文件,这里我只创建map.html文件,代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

<!DOCTYPE html>

<html>

<head lang="en">

    <meta charset="UTF-8">

    <title>三级联动测试</title>

    <script src="/static/jquery-1.8.2.js"></script>

    <script type="text/javascript">

        //用来获得option元素中selected属性为true的元素的id

        function Get_Selected_Id(place){

            var pro = document.getElementById(place);

            var Selected_Id = pro.options[pro.selectedIndex].id;

//            console.log("Get_Selected_Id:"+Selected_Id);  //测试使用

            return Selected_Id;         //返回selected属性为true的元素的id

        }

 

        //执行相应的动作,调用相关数据请求函数

        function Get_Next_Place(This_Place_ID,Action){

            var Selected_Id = Get_Selected_Id(This_Place_ID);   //Selected_Id用来记录当前被选中的省或市的ID

            if(Action=='Get_city')                            //从而可以在下一个级联中加载相应的市或县

                Get_City_Data(Selected_Id);

            else if(Action=='Get_country')

                Get_Country_Data(Selected_Id);

        }

 

        //向服务器请求城市列表数据并调用添加城市函数

        function Get_City_Data(Province_Selected_Id){    //这里的Selected_Id应该是被选中的省份的ID

//            console.log("Province_Selected_Id:"+Province_Selected_Id);   //测试使用

            if(Province_Selected_Id == 'Not_data1'){    //如果选择了"Province"选项,则表示重置当前City和Country的选项内容,不会向服务器请求数据

                $("#city").empty();

                $("#city").append("<option id='Not_data2'>City</option>");

                $("#country").empty();

                $("#country").append("<option id='Not_data3'>Country</option>");

            }else{      //否则就会向服务器请求数据

                $.getJSON('/GetCityData/',{'Province':Province_Selected_Id},function(City_list){

//                    console.log(City_list);      //测试使用

                    Add_city(City_list);    //调用添加城市选项函数

                });

            }

        }

 

        //在当前页面添加城市选项

        function Add_city(City_list){

            $("#city").empty();

            $("#city").append("<option id='Not_data2'>City</option>");

            $("#country").empty();

            $("#country").append("<option id='Not_data3'>Country</option>");

            //上面的两次清空与两次添加是为了保持级联的一致性

            for(var index in City_list){     //获得城市列表中的城市索引

                //添加内容的同时在option标签中添加对应的城市ID

                var text = "<option"+" id='"+City_list[index]+"'>"+City_list[index]+"</option>";

                $("#city").append(text);

                console.log(text);  //用来观察生成的text数据

            }

        }

 

        //向服务器请求县区列表数据并调用添加县区函数

       function Get_Country_Data(City_Selected_Id){

//           console.log("City_Selected_Id:"+City_Selected_Id);   //测试使用

           if(City_Selected_Id == 'Not_data2'){     //如果选择了City选项,则表示重置当前Country的选项内容,不会向服务器请求数据

               $("#country").empty();

               $("#country").append("<option id='Not_data3'>Country</option>");

               //上面的清空与添加是为了保持级联的一致性

           }else{   //否则就会向服务器请求数据

               var Province_Selected_ID = Get_Selected_Id("province");  //获得被选中省的ID,从而方便从服务器中加载数据

               $.getJSON('/GetCountryData/',{'Province':Province_Selected_ID,'City':City_Selected_Id},function(Country_list){

//                   console.log(Country_list);    //测试使用

                   Add_country(Country_list);   //调用添加县区选项函数

               });

           }

        }

 

        //在当前页面添加县区选项

        function Add_country(Country_list){

            $("#country").empty();

            $("#country").append("<option id='Not_data3'>Country</option>");

            //上面的清空与添加是为了保持级联的一致性

            for(var index in Country_list){     //获得县区列表中的县区索引

                //添加内容的同时在option标签中添加对应的城市ID

                var text = "<option"+" id='"+Country_list[index]+"'>"+Country_list[index]+"</option>";

                $("#country").append(text);

                console.log(text);  //用来观察生成的text数据

            }

        }

 

    </script>

</head>

<body>

    <p>您的收货地址:</p>

    <select id="province" onchange="Get_Next_Place('province','Get_city')">

        <option id="Not_data1">Province</option>

        <option id="GuangDong" value="GuangDong">GuangDong</option>

        <option id="ShanDong" value="ShanDong">ShanDong</option>

        <option id="HuNan" value="HuNan">HuNan</option>

    </select>

    <select id="city" onchange="Get_Next_Place('city','Get_country')">

        <option id="Not_data2">City</option>

    </select>

    <select id="country">

        <option id="Not_data3">Country</option>

    </select>

    <br/>

</body>

</html>

    这里的代码相对前面的就有点多,主要是因为在省市县的级联关系、数据的请求与添加上,需要进行相关的逻辑判断,当然,仔细分析,这里的很多代码都可以合并,时间关系,就不进行重构了。


4.测试与实现

    最终的结果是跟前面写的那篇文章一样的,只是不同的是,这里的数据都是来自Web服务器的,用户的每一次点击都会触发一个事件,从而向服务器请求数据。

    就不多说了,有兴趣的朋友可以试一试!

时间: 2024-09-19 09:06:58

Django Web实现动态三级联动的相关文章

用JavaScript实现动态省市县三级联动

 像平时购物选择地址时一样,通过选择的省动态加载城市列表,通过选择的城市动态加载县区列表,从而可以实现省市县的三级联动,下面使用原生的JavaScript来实现这个功能: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58

原生JavaScript实现动态省市县三级联动下拉框菜单实例代码_javascript技巧

像平时购物选择地址时一样,通过选择的省动态加载城市列表,通过选择的城市动态加载县区列表,从而可以实现省市县的三级联动,下面使用原生的JavaScript来实现这个功能: 先给大家展示下测试结果: 未做任何选择时: 选择时: 代码如下所示: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>三级联动测试</titl

基于jQuery+JSON的省市二三级联动效果_jquery

省市区联动下拉效果在WEB中应用非常广泛,尤其在一些会员信息系统.电商网站最为常见.开发者一般使用Ajax实现无刷新下拉联动.本文将讲述,利用jQuery插件,通过读取JSON数据,实现无刷新动态下拉省市二(三)级联动效果. HTML 首先在head中载入jquery库和cityselect插件. <script type="text/javascript" src="js/jquery.js"></script> <script ty

省市区三级联动jquery实现代码_jquery

最近项目需要用到关于省市区三级联动下拉选择的功能,于是乎网上搜了一些做法,觉得有一些只是给出了小的案例,却很难找到详细的省.市.区的具体数据(其实,用baidu搜索就是这样啦),果断用google,搜出来的博文质量相当高,特此记录记录!!!      对于这个效果,其实我发现主要在于两点:1.jquery的筛选遍历操作:2.存储省.市.区这些数据时候的格式.另外一点是如何将获取得到的数据放到select option中(即下拉框中!)      对于第一个问题的解决,其实熟悉Jquery的博友估

用asp+javascript实现动态数据联动,不刷新

javascript|动态|数据|刷新 /////////////by xxrl(孔曰成仁,孟曰取E) /////////////Chinese:蒋健华 /////////////email:jjh_115@eyou.com 联动,联动,联动....困扰了好多网友的神经,在CSDN-ASP板块中,总是看到网友们大呼救命,救什么?联动!为什么联动这样受到关注,其实用性无可非议,用户也能认可,可是如果数据是大量并相互关联的,那问题就来了,怎么识别并显示是一个很苦恼的问题.那究竟有没有一个很好的解决办

一个用webservice behavior实现的三级联动下拉列表框

web|下拉|下拉列表 我做了一个三级联动的下拉列表框,后台用webservice,前台用webservice behavior与后台通讯.请高手们多提改进意见. server端:(service1.asmx.cs)using System;using System.Text;using System.Configuration;using System.Collections;using System.ComponentModel;using System.Data;using System.

ajax-如何去实现三级联动 第三级变成文本框并且能输入值

问题描述 如何去实现三级联动 第三级变成文本框并且能输入值 如图片一样 币种和存期下拉形式 但是年利率要文本框 可输入值 用三级联动 怎么去实现 或者用别的方法 解决方案 首先,你SQL 的设计的时个,这 3 个 字段,是属于 三级联动关系吗?如果不是,你这问题就没有意义! 如果是,就你问题而言,给你个思路: 1 写一个根据 选择币种 ,查找 存期的 接口 2 ajax 去请求这个接口,然后把数据绑定在 存期 这个下拉 (千万别说 你不会 ajax) 3 年利率 你是想直接输入,那你输入,这样问

javascript省市区三级联动下拉框菜单实例演示_javascript技巧

本文实例讲述了javascript实现省市区三级联动下拉框菜单代码,像平时购物选择地址时一样,通过选择的省动态加载城市列表,通过选择的城市动态加载县区列表,从而可以实现省市县的三级联动,下面使用原生的JavaScript来实现这个功能,分享给大家供大家参考.具体如下: 运行效果截图如下: 具体代码如下: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"

求解一奇特三级联动?

问题描述 我用WebService+AjaxControlToolkit来读取表1:Province表2:City表3:Villiage实现了三级联动!但是我想读取Club表里的对应该ProvinceID,CityID,VilliageID并绑定在三级联动上,怎么也绑定不了?如果你有更好的asp.net的三级联动并且能绑定值的,也可以提出来! 解决方案 解决方案二:LZ,你的想法很好,我来学习一下解决方案三:谢谢!现在苦等大家帮解!还是可以加分的哈解决方案四:大家不要放弃我啊!解决方案五:usi