今天遇到了一个一直想做却没有机会去做的功能,今天完成了便记录下来。

那这次是具体是个什么功能呢?其实还是很简单的效果,就是在用户注册的时候可以选择省/市/县,很简单的一个小功能。

那现在就开始了~首先我们要在数据库中先建一个表,用来保存全国的省/市/县信息,下面是表的结构:

CREATE TABLE  IF NOT EXISTS "china_regionalTable" (
"id" integer NOT NULL,
"name" varchar(50) DEFAULT NULL,
"level" integer DEFAULT NULL,
"parent" integer DEFAULT NULL,
PRIMARY KEY ("id")
) ;

剩下的就是按照这个格式去插入数据咯

insert  into "china_regionalTablet"("id","name","level","parent") values (110000,'北京市',1,0),(110100,'市辖区',2,110000).......

现在数据库里有数据了,因为我用的是Python的SQLAlchemyORM框架,所以下面就要写model类来与数据库中的表进行映射了

class ChinaRegionalTable(dash_models.Base):
__tablename__ = 'china_regionalTable' id = Column(SmallInteger,nullable=False,primary_key=True)
name = Column(String(200))
level = Column(SmallInteger,nullable=False)
parent = Column(SmallInteger,nullable=False)

那么现在就是在view层来处理来自前端的请求了

#注册页面选择区县
def get_city(request):
parent = int(request.POST['parent'])
level = request.POST['level']
s = request.get_session()
citys = s.query(ChinaRegionalTable).filter_by(parent=parent,level=level).all()
dict_city = []
for city in citys:
temp = []
temp.append(city.id)
temp.append(city.name)
dict_city.append(temp)
return HttpResponse(json.dumps({"dict_city":dict_city}))

这其中是通过get_session()来取得与数据库的连接的,下面就是一个URL的路由表了

url(r'^ajax/get_city/$' ,'get_city'),

接下来就是前端页面的代码了,首先是部分静态的HTML代码:

<div class="input-group" style="margin-bottom: 10px;margin-left: 70px;">
<span class="input-group-addon" style="padding: 5px 10px"><i class="glyphicon glyphicon-info-sign"></i></span>
<select id="shengcode" >
<option selected value="">请选择省份</option>
</select>
<select id="shicode" >
<option selected value="">请选择</option>
</select>
<select id="xiancode" >
<option selected value="">请选择</option>
</select>
</div>

因为使用的是jQuery,所以采用的是当页面第一次加载完成的时候就发送一个ajax请求到后台取得第一级的内容,然后绑定事件,当我选择第一级下拉菜单中的内容的时候我便会去后台查找,然后返回第二级菜单的内容,从而以此类推,直到结束。

$(function(){
$.ajax({
type:'POST',
url:'/app/ajax/get_city/',
data:{"parent":0,"level":1},
success:function(data){
var all_ps=data['dict_city']
<!--这里取得结果后,然后遍历出结果填充在对应的html页面中-->
for(var i=0;i<all_ps.length;i++){
var $html=String.format('<option value="{0}">{1}</option>',all_ps[i][0],all_ps[i][1])
$('#shengcode').append($html)
}
},
error: function (jqXHR, textStatus, errorThrown) {
console.log("error");
},
dataType: 'json'
});
        $('#shengcode').change(function(){
var parent = $('#shengcode').val()
$.ajax({
type:'POST',
url:'/app/ajax/get_city/',
data:{"parent":parent,"level":2},
success:function(data){
var all_ps=data['dict_city']
<!--在填充之前将后面的几个下拉菜单制空-->
var $shicode = $('#shicode').empty();
$shicode.append('<option selected value="">请选择</option>')
var $xiancode = $('#xiancode').empty();
$xiancode.append('<option selected value="">请选择</option>')
for(var i=0;i<all_ps.length;i++){
var $html=String.format('<option value="{0}">{1}</option>',all_ps[i][0],all_ps[i][1])
$('#shicode').append($html)
}
},
error: function (jqXHR, textStatus, errorThrown) {
console.log("error");
},
dataType: 'json'
});
}) $('#shicode').change(function(){
var parent = $('#shicode').val()
$.ajax({
type:'POST',
url:'/app/ajax/get_city/',
data:{"parent":parent,"level":3},
success:function(data){
var all_ps=data['dict_city']
var $xiancode = $('#xiancode').empty();
$xiancode.append('<option selected value="">请选择</option>')
for(var i=0;i<all_ps.length;i++){
var $html=String.format('<option value="{0}">{1}</option>',all_ps[i][0],all_ps[i][1])
$('#xiancode').append($html)
}
},
error: function (jqXHR, textStatus, errorThrown) {
console.log("error");
},
dataType: 'json'
});
})
})

到此为止,这个简单的小功能就算彻底实现了,但是还是有个小小的不爽,就是虽然三次请求都是使用的一个url地址,而且也都使用的是一个view函数来处理的,但是前端的js代码却要写三次,感觉有些累赘,如果能有更好的意见感谢各位大神告知小弟Orz….

Django分析之三级下拉菜单选择省/市/县的更多相关文章

  1. excel选择元角分下拉菜单选择框自动变更数字

    excel选择元角分下拉菜单选择框自动变更数字 (M2列),数据-->数据有效性-->在“允许”栏中选择序列-->在“来源”栏中输入:分,角,元单位倍数公式(M4列):=IF(M2= ...

  2. Atitit.ui控件---下拉菜单选择控件的实现select html

    Atitit.ui控件---下拉菜单选择控件的实现select   html 1. 调用& model的实现 1 2. -----select.jsp------ 1 1. 调用& m ...

  3. jQuery 当前展开其他收缩 三级下拉菜单(转载)

    jQuery可展开收缩三级下拉菜单 <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...

  4. [jquery]添加行内容后根据下拉菜单选择内容对比之前已有选项,若有重置再提示

    今天页面上一个添加列内容时,要对选择内容与之前已有选项内容作对比,防止用户重复选择内容 页面HTML代码 <ul class="list-group xj-list-NObor xj- ...

  5. CSS打造三级下拉菜单

    <html><head><meta http-equiv="Content-Type" content="text/html; charse ...

  6. 下拉菜单选择(jQuery实现)

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

  7. Axure-----三级下拉菜单的具体实现过程

    ********三级下拉菜单的动画效果:********** 1.选中三级菜单将其转换为动态面板,命名为treePanel,并隐藏. 2.选中二级菜单添加交互效果:[切换可见性],勾选treePane ...

  8. jQuery 前端复选框 全选 反选 下拉菜单联动

    jQuery 页面中复选框全选.反选.下拉联动(级联) <!DOCTYPE html> <html lang="en"> <head> < ...

  9. (实用篇)jQuery+PHP+MySQL实现二级联动下拉菜单

    二级联动下拉菜单选择应用在在很多地方,比如说省市下拉联动,商品大小类下拉选择联动.本文将通过实例讲解使用jQuery+PHP+MySQL来实现大小分类二级下拉联动效果. 先看下效果 大类:  前端技术 ...

随机推荐

  1. Android开发环境的搭建

    在学习android时,环境的搭建是学习android的第一步,为了记住第一步特写了这篇文章. 第一步,安装jdk,因为eclipse的运行需要jdk才可以,所以jdk的安装时第一步.安装过程和普通的 ...

  2. kindeditor在光标处插入编辑器外的数据

    页面 <div class="form-group clearfix"> <label class="control-label col-sm-3 co ...

  3. App-Pass the password

    V1.0 初始版本 注册一个帐号却不想使用简单密码? Pass the Password! 输入任意字符串,如反写或截取网站域名,我们帮你生成高安全性密码. 记住规则,忘记密码 . 下一次依照你的规则 ...

  4. CSS3 之 flexbox 响应式的未来

    CSS3 之 flexbox 响应式的未来 flexbox 伸缩盒模型 . flex: CSS3中一个重要的而且非常有用的属性,用来制作弹性布局是非常的方便而又强大. . flex布局:旨在提供一个更 ...

  5. STM32f103之外部中断

    一.背景 有个需求,IO口检测上升沿,然后做相应的动作.在此记录STM32F103的外部中断结构及配置方法, 以备下次快速上手使用. 有许多不太明白,又是老司机(:-D)帮忙,真的是站在别人的肩膀上会 ...

  6. Mac Pro 资源管理器 Double Commander“个性化设置” 备份

    操作系统自带的资源管理器,总是有些别扭的地方,在 Windows 系统下,我一般用 Total Commander(破解版)来作为替代品.现在换为 Mac 系统,自带的 Finer 也不怎么好用,连最 ...

  7. C语言运算符优先级 详细列表

    首先还是插入原博客的地址http://blog.csdn.net/huangblog/article/details/8271791 另外还有一个参考博客http://www.slyar.com/bl ...

  8. linux source

    清华TUNA镜像源https://mirrors.tuna.tsinghua.edu.cn/ 中科大USTC镜像源 https://mirrors.ustc.edu.cn/ ali http://mi ...

  9. android:layout_height、android:layout_width、android:height、android:width的关系与区别

    一直一来对android:layout_height.android:layout_width.android:height.android:width这几个属性的关系有些不理解,既然有了androi ...

  10. 逻辑思维面试题-java后端面试-遁地龙卷风

    (-1)写在前面 最近参加了一次面试,对笔试题很感兴趣,就回来百度一下.通过对这些题目的思考让我想起了建模中的关联,感觉这些题如果没接触就是从0到1,考验逻辑思维的话从1到100会更好,并且编程简易模 ...