> Form操作 采用ModelForm 部分字段 保存 头像
<form class="clearfix" id="jsAvatarForm" enctype="multipart/form-data"
autocomplete="off"
method="post" action="{% url 'users:usercenter_resetimage' %}" target='frameFile'>
{% csrf_token %}
<label class="changearea" for="avatarUp">
<span id="avatardiv" class="pic">
<img width="100" height="100" class="js-img-show" id="avatarShow"
src="{{ MEDIA_URL }}{{ request.user.image }}"/>
</span>
<span class="fl upload-inp-box" style="margin-left:70px;">
<span class="button btn-green btn-w100" id="jsAvatarBtn">修改头像</span>
<input type="file" name="image" id="avatarUp" class="js-img-up"/>
</span>
</label>
</form>
配好url后 因为是post提交过来的数据,新建form验证,采用ModelForm,
确保 字段name的统一性,
class UserResetImageForm(forms.ModelForm):
class Meta:
model = UserProfile
fields = ['image']
注意点来了:注意 instance=request.user
回到 views 补充函数 因为是用ModelForm修改 部分字段,这时候需要指定修改的是哪个实例,否则是新建,字段不完整,会报错;
def usercenter_resetimage(request):
userresetform = UserResetImageForm(request.POST, request.FILES, instance=request.user)
if userresetform.is_valid():
userresetform.save(commit=True)
return JsonResponse({'status': 'ok'})
else:
return JsonResponse({'status': 'faile'})
程序猿的道德修养:
本博客源码Github地址:
https://github.com/whisnos/myblog
(仅供学习使用)请随手给个star,谢谢