python复选框_Django开发中复选框用法示例

本文实例讲述了Django开发中复选框用法。分享给大家供大家参考,具体如下:

一、查询数据库遍历所有的复选框

1、python查询数据库所有的tag

# 新增文章

def add(request):

if request.method == 'GET':

tags = TagModel.objects.all()

return render(request, 'books_add.html', {'tags': tags})

elif request.method == 'POST':

title = request.POST.get('title', None)

content = request.POST.get('content', None)

blogModel = BlogModel(title=title, content=content, author=AuthorModel.objects.get(id=1))

blogModel.save()

# 获取复选框的值,是一个选中的数组

tags = request.POST.getlist('tags')

# 循环遍历所有选中的复选框,利用多对多的关系追加到数据库

for tag in tags:

blogModel.tag.add(tag)

return HttpResponseRedirect('book_add')

else:

return HttpResponse(u'是不被处理的请求方式')

2、前端页面

标签

{% for tag in tags %}

{{ tag.name }}

{% endfor %}

3、进入编辑页面,先获取全部的复选框及选中的id

# 编辑博客

def edit(request, blog_id):

tags = TagModel.objects.all()

# 利用正向查找关于本博客选择的tag

blogModel = BlogModel.objects.filter(id=blog_id).first()

# 获取全部的tag

check_tag = blogModel.tag.all()

# 获取选中的id

check_id = [int(x.id) for x in check_tag]

print check_id

return render(request, 'books_edit.html', {'tags': tags, 'check_id': check_id})

4、判断如果选中的就勾选

标签

{% for tag in tags %}

{% if tag.id in check_id %}

{{ tag.name }}

{% else %}

{{ tag.name }}

{% endif %}

{% endfor %}

二、ajax提交的时候注意要把复选框转换字符串提交

1、前端代码

$('#btn').on('click', function (e) {

// 设置空数组

var hobby = [];

$('#hobby-group').find('input[type=checkbox]').each(function () {

if ($(this).prop("checked")) {

var hobbyId = $(this).val();

hobby.push(hobbyId);

}

})

console.log(hobby);

$.ajax({

'url': '/ajaxpost/',

'method': 'post',

'data': {

'username': $('.username').val(),

'hobby': hobby

},

'traditional': true,

'beforeSend': function (xhr, settings) {

var csrftoken = ajaxpost.getCookie('csrftoken');

//2.在header当中设置csrf_token的值

xhr.setRequestHeader('X-CSRFToken', csrftoken);

},

'success': function (data) {

console.log(data);

}

})

})

2、后端代码

@require_http_methods(['POST'])

def ajaxpost(request):

form = LoginForm(request.POST)

if form.is_valid():

username = form.cleaned_data.get('username', None)

# 获取复选框的值

hobby = request.POST.getlist('hobby')

print '*' * 100

print hobby

print '*' * 100

return HttpResponse(u'成功')

else:

return HttpResponse(u'验证错误')

希望本文所述对大家Django框架的Python程序设计有所帮助。

本文标题: Django开发中复选框用法示例

本文地址: http://www.cppcns.com/jiaoben/python/223184.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值