一、iframe使用

iframe在一个页面中,相当于整个window窗口的子窗口,可通过页面的元素结构查看。

<div>
<p>学习iframe</p>
<form id='form' action="ajax1" method="post" target="ifra">
<input type="text">
<input type="button" value="提交" class="btn" onclick="ajaxSubmit5()">
</form>
<iframe id="iframe" name="ifra" style="height: 100px;width: 250px;" ></iframe>
</div>
……
function ajaxSubmit5() {
document.getElementById('iframe').onload = reloadIframe;
$('#form').submit();
} function reloadIframe() {
//ret = this.contentWindow.document.body.innerText
ret = $(this).contents().find('body').text()
data = JSON.parse(ret)
if (data.status == 'success')
alert('welcome')
}

创建iframe和Form表单

def ajax1(request):
print(request.GET)
print(request.POST)
print(request.body)
ret = {'status':'success','data':[1,'hello']}
return HttpResponse(json.dumps(ret))

后台处理函数

执行过程:

①在输入框输入内容并点击提交,执行ajaxSubmit5(),并通过submit()向后台提交数据;

②由于在form表单中设置了target="ifra",即target为iframe的name值,因此后台HttpResponse的返回值传递给iframe

③后台向iframe传递返回值时,即onload触发reloadIframe()

④在reloadIframe()中,通过this.contentWindow.document.body.innerText获取iframe的显示内容,即HttpResponse的返回值,再进行判断。

      

二、利用iframe+form上传文件

<form id='form1' action="ajax1" method="post" target="ifra1" enctype="multipart/form-data">
<input type="text" name="k1">
<input type="text" name="k2">
<input type="file" name="k3">
<input type="button" value="提交" class="btn" onclick="ajaxSubmit8()">
</form>
<iframe id="iframe1" name="ifra1" style="display: none;"></iframe>

模板

function ajaxSubmit8() {
$('#form1').submit();
document.getElementById('iframe1').onload = reloadIframe1;
} function reloadIframe1() {
ret = this.contentWindow.document.body.innerHTML
data = JSON.parse(ret)
if (data.status == 'success')
alert('welcome')
}

iframe+form

def ajax1(request):
print(request.POST)
print(request.FILES)
obj = request.FILES.get('k3')
file_path = os.path.join('static', obj.name)
with open(file_path, 'wb') as f:
for line in obj.chunks():
f.write(line)
ret = {'status':'success','data':[1,'hello']}
return HttpResponse(json.dumps(ret))

后台处理函数

三、利用ajax+FormData上传文件

<input type="file" id="img">
<input type="button" class="btn" value="提交" onclick="ajaxSubmit6()">
<input type="button" class="btn" value="提交" onclick="ajaxSubmit7()">
……

模板

function ajaxSubmit6() {
var data = new FormData() //使用FormData时,需要在ajax中添加processData和contentType两个参数
data.append('k1','v1')
data.append('k2','v2')
f = $('#img')[0].files[0]
data.append('k3',f)
$.ajax({
url:'ajax1',
type:'POST',
data:data,
processData:false,
contentType:false,
success:function (arg) {
console.log(arg)
}
})
} function ajaxSubmit7() {
var data = new FormData()
//使用FormData来传递数据时,无论是使用jQuery还是原生的XMLHttpRequest,都不能在后台使用request.body,数据在request.POST和request.FILES中
data.append('k1','v1')
data.append('k2','v2')
f = $('#img')[0].files[0]
data.append('k3',f)
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.readyState == 4)
console.log(xhr.responseText);
}
xhr.open('POST','ajax1');
xhr.send(data);
}

ajax+FormData

def ajax1(request):
print(request.POST)
print(request.FILES)
obj = request.FILES.get('k3')
file_path = os.path.join('static', obj.name)
with open(file_path, 'wb') as f:
for line in obj.chunks():
f.write(line)
ret = {'status':'success','data':[1,'hello']}
return HttpResponse(json.dumps(ret))

后台处理函数

四、利用iframe+form上传并生成图片预览

<form id='form1' action="upload_file" method="post" target="ifra1" enctype="multipart/form-data">
<input type="file" name="k3" onchange="uploadFile()">
</form>
<iframe id="iframe1" name="ifra1" style="display: none;"></iframe>
<div>预览</div>
<div id="preview"></div>

模型

def upload_file(req):
if req.method == 'GET':
return render(req,'upload.html')
else:
ret = {'status': True, 'data': None, 'message': None}
obj = req.FILES.get('k3')
nid = str(uuid.uuid4())
file_path = os.path.join('static', nid + obj.name)
with open(file_path, 'wb') as f:
for line in obj.chunks():
f.write(line)
ret['data'] = file_path
return HttpResponse(json.dumps(ret))

后台处理函数

<script src="/static/jquery-3.3.1.min.js"></script>
<script>
function uploadFile() {
document.getElementById('iframe1').onload = reloadIframe1;
$('#form1').submit();
} function reloadIframe1() {
ret = this.contentWindow.document.body.innerHTML
obj = JSON.parse(ret)
console.log(obj)
var tag = document.createElement('img') //创建img标签
tag.src = obj.data //设置img标签的src为本地已上传图片的路径
$('#preview').empty().append(tag) //清空预览图片并上传新的图片
}
</script>

iframe+form

iframe和DataForm的更多相关文章

  1. 完美判断iframe是否加载完成

    var iframe = document.createElement("iframe"); iframe.style.width = "265px"; ifr ...

  2. js学习笔记:操作iframe

    iframe可以说是比较老得话题了,而且网上也基本上在说少用iframe,其原因大致为:堵塞页面加载.安全问题.兼容性问题.搜索引擎抓取不到等等,不过相对于这些缺点,iframe的优点更牛,跨域请求. ...

  3. 页面嵌入dom与被嵌入iframe的攻防

    1.情景一:自己的页面被引入(嵌入)至别人的页面iframe中 if(window.self != window.top){ //url是自己页面的url window.top.location.hr ...

  4. iframe用法

    <iframe src="http://caiyanli.top/" height="500"  width="500" frameb ...

  5. 如何获取url中的参数并传递给iframe中的报表

    在使用报表软件时,用户系统左边一般有目录树,点击报表节点就会在右侧网页的iframe中显示出报表,同时点击的时候也会传递一些参数给网页,比如时间和用户信息等.如何使网页中的报表能够获取到传递过来的参数 ...

  6. JavaScript权威设计--Window对象之Iframe(简要学习笔记十四)

    1.Window对象属性的文档元素(id) 如果在HTML文档中用id属性来为元素命名,并且如果Window对象没有此名字的属性,Window对象会赋予一个属性,它的名字是id属性的值,而他们的值指向 ...

  7. ASP.NET 页面禁止被 iframe 框架引用

    两个站点: a.sample.com b.sample.com a.sample.com 站点中的一段示例 JS 代码: var iframe = document.createElement(&qu ...

  8. 父页面操作iframe子页面的安全漏洞及跨域限制问题

    一.父子交互的跨域限制 同域情况下,父页面和子页面可以通过iframe.contentDocument或者parent.document来交互(彼此做DOM操作等,如父页面往子页面注入css). 跨域 ...

  9. 解决iframe作为子窗口,刷新后iframe页面跳转到其它页面的问题

    转载请在页首注明作者与出处 http://www.cnblogs.com/zhuxiaojie/p/5990262.html 前言: 在开发网站时,尤其是管理后台,我们经常会使用iframe作为内容窗 ...

随机推荐

  1. 重学 Java 设计模式:实战备忘录模式「模拟互联网系统上线过程中,配置文件回滚场景」

    作者:小傅哥 博客:https://bugstack.cn - 原创系列专题文章 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 实现不了是研发的借口? 实现不了,有时候是功能复杂度较高难以实 ...

  2. .net Core中如何读取Appsetting配置文件

    现在APPSetting下面配置以下节点 { "Logging": { "IncludeScopes": false, "LogLevel" ...

  3. 【必读】前端需要懂的 APP 容器原理

    App 容器,简言之,App 承载某类应用(H5/RN/Weex/小程序/Flutter ...)的运行环境,可主动干预并进行功能扩展,达到丰富能力.优化性能.提升体验的目的,如页面数据预取(pref ...

  4. Oracle Solaris 10下gdb安装(附安装包)

    文章目录 1. 背景说明 2. gdb相关包 3. gdb安装 3.1 上传资源 3.2 解压 3.3 安装 3.4 环境变量 4. 位数确认 5. 验证可用性 1. 背景说明 本文承接Oracle ...

  5. 作为架构师必须知道的Netty原理和使用

    本文首发于微信公众号[猿灯塔],转载引用请说明出处 今天呢!灯塔君跟大家讲: Netty应用 一.Netty简介 1.Netty下载 官网:https://netty.io/downloads.htm ...

  6. webpack正式、测试环境接口地址本地运行及打包命令配置

    声明:本文由w3h5原创,转载请注明出处:<webpack正式.测试环境接口地址本地运行及打包命令配置> https://www.w3h5.com/post/521.html 为了方便开发 ...

  7. 日期推算:datetime

    >>> import datetime >>> datetime.datetime.now() datetime.datetime(2020, 5, 20, 23, ...

  8. JS基础知识点(二)

    == 与 === 对于 == 来说,如果对比双方的类型不一样的话,就会进行类型转换,就会进行如下判断流程: 1.首先会判断两者类型是否相同,相同则会进行严格相等比较=== 2.判断是否在对比null和 ...

  9. WeChat小程序开发-初学者笔记(一)

    WeChat小程序开发学习第一天: 完成学习目标: 1.安装并了解Wechat小程序的基本环境, 2.可以利用已学知识的结合简单实现helloWorld界面. 学习过程: 1.首先在微信平台上进行相关 ...

  10. one-hot 编码

    def onehot(labels): '''one-hot 编码''' #数据有几行输出 n_sample = len(labels) #数据分为几类.因为编码从0开始所以要加1 n_class = ...