Django下用户详情页展示

Django下用户详情页展示

主要分四个模块:
第一,详情页html文件,加载对应的js文件
第二,url模块
第三,serializer模块(创建序列化器)
第四,view模块(实现对应的功能)

1、html模块

//这是一个入口函数
$(function(){
    token=localStorage.token
    //这个ajax是为了将初始的登录用户信息展示出来,这个页面是通过登录界面跳转过来的,通过请求头的token向后端请求数据,当用户的用户名和密码正确的时候,跳转到当前页面,并且展示该用户的详细信息
    $.ajax({
        url:'http://127.0.0.1:8000/users/userinfo/',
        method:'GET',
        headers:{'Authorization':'JWT '+token},
        success:function (data) {
            username = data['username'];
            phone= data['phone'];
            email=data['email'];
            user_id=data['id'];
            is_active = data['is_active']
            $('#myusername').val(username);
            $('#myrealname').val(username);
            $('#myusername2').text(username);
            $('#email').val(email);
            $('#phone').val(phone);
            if(is_active){
                $('#active_flag').val('是');
            }else {
                $('#active_flag').val('否');
            }
        },
        error:function () {
            alert('失败')
        }

    })

    //todo  修改用户的信息
    //这个单击函数是确认修改的按钮,当用户有信息需要修改的时候,通过此按钮确认修改的信息。
    $('#sub_btn').click(function () {
        // alert('ok')
        //将修改的值获取出来
        username = $('#myusername').val();
        email= $('#email').val();
        phone = $('#phone').val();
        data = {
            'username':username,
            'email':email,
            'phone':phone
        }
        data_json = JSON.stringify(data)
        $.ajax({
            url:'http://127.0.0.1:8000/users/userinfo/',
             headers:{
            'Authorization':'JWT ' + token
        },
        //部分修改,也可以用patch请求
            type:'PUT',
            data:{
            //_method是put请求的固定用法
                _method:'PUT',
                'username':username,
                'email':email,
                'phone':phone
            },
            dataType:'json',
            success:function () {
                alert('ok')
            }
       
    })
    })
})

2.url模块(个人记录,没什么好说的)

跳转

 url(r'^userinfo/$',views.UserInfoView.as_view())

3.Serializer模块

#这里的id和is_active字段是只读字段,前端传过来没关系,后端不会返回这些字段
class UserInfoSerializer(serializers.ModelSerializer):
    '''
    这个序列化器用来返回我们单个对象的
    '''
    class Meta:
        model = models.User
        fields = ['id','username','phone','email','is_active']
        read_only=['id','is_active']

4.View模块

class UserInfoView(RetrieveUpdateAPIView):
	#指定使用的序列化器
    serializer_class = serializers.UserInfoSerializer
    #指定访问的权限
    permission_classes = [IsAuthenticated]
    def get_object(self):
       	#重写方法,当登录成功之后,框架会自动帮你将登陆成功的用户的信息赋值给request中的user
        return self.request.user

注:

通过请求方式的不同进入不同的方法,put请求进入修改方法,get请求进入访问方法

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值