django 上传头像并预览 3选1
注册页面的头像上传 register.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div style="margin-left: 30px; margin-top: 30px">
<form action="">
{% csrf_token %}
<h3>用户注册</h3>
<p>用户名:<input type="text" name="user"></p>
<p>密 码 :<input type="password" name="pwd"></p>
<p>再输入:<input type="password" name="pwd"></p>
<p>昵 称 :<input type="text" name="nickname"></p>
<p>邮 箱 :<input type="text" name="email"></p>
<input id="avatar" type="file" value="上传头像"> {# 实际应用中要将该input标签隐藏,display:none; #}
<p><input type="submit" value="注册" style="margin-left:50px;width:100px;"></p>
</form>
<div style="position: absolute; top: 85px; left: 300px;">
<input id="avatarSelect" type="file" style="position: absolute;float: left; z-index: 10; opacity: 0;width: 100px; height: 100px;">
<img id="avatarPreview" src="/static/img/default.png" title="点击更换图片" style="position: absolute; z-index: 9; float: left; width: 100px; height: 100px">
</div>
</div>
</body> <script src="\static\jquery-3.3.1.min.js"></script>
<script>
$(function () {
bindAvatar();
}); function bindAvatar() {
if(window.URL.createObjectURL){
bindAvatar3();
}else if(window.FileReader){
bindAvatar2();
}else {
bindAvatar1();
}
} /*Ajax上传至后台并返回图片的url*/
function bindAvatar1() {
$("#avatarSelect").change(function () {
var csrf = $("input[name='csrfmiddlewaretoken']").val();
var formData=new FormData();
formData.append("csrfmiddlewaretoken",csrf);
formData.append('avatar', $("#avatarSelect")[0].files[0]);
console.log(formData);
/*获取上传的图片对象*/
$.ajax({
url: '/avatar_load/',
type: 'POST',
data: formData,
contentType: false,
processData: false,
success: function (args) {
console.log('年后哦')
console.log(args); /*服务器端的图片地址*/
$("#avatarPreview").attr('src','/'+args); /*预览图片*/
$("#avatar").val('/'+args); /*将服务端的图片url赋值给form表单的隐藏input标签*/
}
})
})
}
/*window.FileReader本地预览*/
function bindAvatar2() {
console.log(2);
$("#avatarSelect").change(function () {
var obj=$("#avatarSelect")[0].files[0];
var fr=new FileReader();
fr.readAsDataURL(obj);
fr.onload=function () {
$("#avatarPreview").attr('src',this.result);
console.log(this.result);
$("#avatar").val(this.result);
};
fr.readAsDataURL(obj);
})
}
/*window.URL.createObjectURL本地预览*/
function bindAvatar3() {
console.log(3);
$("#avatarSelect").change(function () {
var obj=$("#avatarSelect")[0].files[0];
var wuc=window.URL.createObjectURL(obj);
$("#avatarPreview").attr('src',wuc);
$("#avatar").val(wuc);
{# $("#avatarPreview").load(function () {#} /*当图片加载后释放内存空间,但在jQuery3.2.1中会报错。浏览器关闭后也会自动释放*/
{# window.URL.revokeObjectURL(wuc);#}
{# })#}
})
} </script>
</html>
视图函数
def register(request):
"""注册
:param request
:return"""
if request.method == 'GET':
return render(request,'register.html') def avatar_reg(request):
"""
:param request: (avatar头像对象)
:return:
"""
file_obj = request.FILES.get('avatar')
file_path = os.path.join('static/img',file_obj.name)
with open(file_path,'wb') as f:
for chunk in file_obj.chunks():
f.write(chunk)
print file_path
return HttpResponse(file_path)
路由系统 url.py
from django.conf.urls import url
from django.contrib import admin
from app_boke import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^all/(?P<url_id>\d+)/', views.test),#正则p是大写,页面的参数和type_id组成键值对穿个函数中的变量kwargs
url(r'^$', views.test), #默认输入域名或ip到达首页,上下兼容,必须加斜杠或者终止符不然可能跟其他的url有路径冲突(这种匹配追号写到地下,匹配是从上往下)
url(r'^login/', views.login),
url(r'^ajax_login/', views.ajax_login),
url(r'^login1/', views.login1),
url(r'^index/', views.index),
url(r'^check_code/', views.check_code),
url(r'^register/', views.register),
url(r'^avatar_load/', views.avatar_reg),
]
Form表单组件出现的错误信息
{
__all__:[错误1,错误2], 整体共有的错误
user:[错误1,错误2],
password:[错误1,错误2],
}
#获取整体。共有错误信息
-后台 对象的errors属性
print(obj.errors['__all__'])或者 #参考源码
print(obj.errors['NON_FIELD_ERRORS'])
-模板(前端)
{{obj,non_filed_errors}} 特殊
django 上传头像并预览 3选1的更多相关文章
- [.ashx檔?泛型处理例程?]基础入门#2....FileUpload上传前,预览图片(两种作法--ashx与JavaScript)
原文出處 http://www.dotblogs.com.tw/mis2000lab/archive/2013/08/20/ashx_beginner_02_fileupload_picture_p ...
- Ajax上传图片以及上传之前先预览
手头上有几个小项目用到了easyUI,一开始决定使用easyUI就注定了项目整体上前后端分离,基本上所有的请求都采用Ajax来完成.在文件上传的时候用到了Ajax上传文件,以及图片在上传之前的预览效果 ...
- 关于confluence上传文件附件预览查看时出现乱码的问题解决办法
在confluence上传excel文件,预览时发现乱码问题主要是因为再上传文件的时候一般是Windows下的文件上传,而预览的时候,是linux下的环境,由于linux下没有微软字体,所以预览的时候 ...
- java多图片上传--前端实现预览--图片压缩 、图片缩放,区域裁剪,水印,旋转,保持比例。
java多图片上传--前端实现预览 前端代码: https://pan.baidu.com/s/1cqKbmjBSXOhFX4HR1XGkyQ 解压后: java后台: <!--文件上传--&g ...
- confluence上传文件附件预览乱码问题(linux服务器安装字体操作)
在confluence上传excel文件,预览时发现乱码问题主要是因为再上传文件的时候一般是Windows下的文件上传,而预览的时候,是linux下的环境,由于linux下没有微软字体,所以预览的时候 ...
- jsp+springmvc实现文件上传、图片上传和及时预览图片
1.多文件上传:http://blog.csdn.net/a1314517love/article/details/24183273 2.单文件上传的简单示例:http://blog.csdn.net ...
- web 图片上传实现本地预览
在说上传之前先说说如何替换or美化浏览器自带的简陋上传按钮(自定义自己的上传按钮 如:img): 1.将自定义上传按钮上方添加 input file 框,实现input实现透明处理. 2.对自定义上传 ...
- 图片上传前的预览(PHP)
1.先创建一个file表单域,我们需要用它来浏览本地文件.<form name="form1" id="form1" method="post& ...
- DAY19-上传头像并预览
一个简单的注册页面: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
随机推荐
- 每日题解: 两数之和 & 有效的括号
- 【转载】 TensorFlow函数:tf.Session()和tf.Session().as_default()的区别
原文地址: https://blog.csdn.net/Enchanted_ZhouH/article/details/77571939 ------------------------------- ...
- Python用积分思想计算圆周率
[文本出自天外归云的博客园] 早上起来突然想求圆周率,1单位时圆的面积. 代码如下: from math import pow, sqrt def calc_circle_s_with(r, dy, ...
- WebGL学习笔记(十四):一些零碎的记录
HUD和Billboard 这两个名词都指向同一种东西,即始终面向摄像机的面片,该技术在游戏中大量使用,比如UI的绘制.模型头顶的名称和血条等等都需要使用到. 交换缓冲区 在PC上使用的OpenGL开 ...
- Ubuntu16.04安装Supervisor
安装 sudo apt-get install supervisor 启动,否则会报 unix:///tmp/supervisor.sock no such file service supervis ...
- [Linux.centOS].安装Redis 腾讯云
环境 { "服务器运营商":"腾讯云", "操作系统":"CentOS 7.5 64位", "CPU" ...
- 启动Oracle 12c数据库实例
启动Oracle 12c数据库实例 启动Oracle数据库实例,主要分为两步:第一步,启动监听:第二步,启动数据库实例. 1. 切换到oracle用户- su oracle- cd - source ...
- (CSDN 迁移) JAVA循环删除List的某个元素
若列表中只可能存在一个则可以用简单的循环删除,不多说. 若列表中可能存在多个,尤其是可能有多个连续的需要删除,用简单循环有可能发生异常. 需要使用迭代器(Iterator),两种具体实现: 逻辑上是一 ...
- beanshell 通过java写数据到文件
import java.io.*; String filePath = "/data/account.txt"; String conent = vars.get("ac ...
- Java开发笔记(一百四十八)通过JDBC查询数据记录
前面介绍了通过JDBC如何管理数据库,当时提到Statement专门提供了executeQuery方法用于查询操作,为什么查询操作这么特殊呢?这是因为其它语句跑完一次就了事了,顶多像insert.up ...