文件上传,iframe跨域数据提交的实现


Posted in Javascript onNovember 18, 2016

1、文件上传,图片上传,第三方uploadify插件,http://www.uploadify.com/about/

2、用iframe上传文件,提交表单,主要思路就是:

 a、js创建form表单,iframe,添加到body里,form的target要和iframe的name一致。

 b、form表单里更新数据,submit提交

 c、如果上传文件,图片,form里面添加 input-file 元素,绑定onchange事件,js触发,在onchange里面添加submit事件

 d、关于回调:iframe提交成功后,返回的数据在iframe子页面的里面,可以这样获取,需要拆分:

$iframe[0].contentWindow.document.querySelector('body').innerHTML

代码片:

 

var target = 'frameFile';
var input = '<input type="file" name="file" onchange="changeImage()">' +
  '<input name="appId" value="'+id+'">' +
  '<input type="submit" name="submit" value="submit">';
var $form = $('<form action="'+ url +'" target="'+ target +'" enctype="multipart/form-data" method="post" id="upImageForm" style="display:none">'+input+'</form>').appendTo('body');
var $iframe = $('<iframe name="'+ target +'" style="display:none"></iframe>').appendTo('body');
$form.find('input').eq(0).click();
window.changeImage = function(){
  $form.find('input').eq(-1).click();
};

//检测iframe页面load
$iframe.load(function(e){
  var str = $iframe[0].contentWindow.document.querySelector('body').innerHTML;
  var data = spt(str);
  $form.remove();
  $iframe.remove();
  callback(data);
});
function spt(str){
  //字符串拆成对象
  var a = str.indexOf('{');
  var b = str.indexOf('}');
  var j = {};
  var t = [];
  var s = str.substring(a+1,b);
  s = s.replace(/"/gi,'');
  t = s.split(',');
  for(var i=0; i<t.length; i++ ){
    var tmp = t[i].split(':');
    j[tmp[0]] = tmp[1];
  };
  return j;
};

 2-c修正,以上代码有bug:

手动触发input-file的onchange事件,在事件里面submit,这做法有问题。因为触发onchange事件,选择才开始,submit就已经提交了。

上传功能,form表单元素只能放到html里。

以上这篇文件上传,iframe跨域数据提交的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 数据缓存data(name, value)详解及实现
Jan 04 Javascript
怎样在JavaScript里写一个swing把数据插入数据库
Dec 10 Javascript
jquery实现隐藏与显示动画效果/输入框字符动态递减/导航按钮切换
Jul 01 Javascript
深入理解jQuery中live与bind方法的区别
Dec 18 Javascript
详解Vue CLI 3.0脚手架如何mock数据
Nov 23 Javascript
jQuery实现根据身份证号获取生日、年龄、性别等信息的方法
Jan 09 jQuery
vue+element+Java实现批量删除功能
Apr 08 Javascript
送你43道JS面试题(收藏)
Jun 17 Javascript
微信小程序自定义弹出层效果
May 26 Javascript
Vue中的this.$options.data()和this.$data用法说明
Jul 26 Javascript
解决ant design vue 表格a-table二次封装,slots渲染的问题
Oct 28 Javascript
Vue Element UI自定义描述列表组件
May 18 Vue.js
jQuery实现自动调用和触发某个事件的方法
Nov 18 #Javascript
jQuery与JavaScript节点创建方法的对比
Nov 18 #Javascript
用iframe实现不刷新整个页面上传图片的实例
Nov 18 #Javascript
Form表单按回车自动提交表单的实现方法
Nov 18 #Javascript
form+iframe解决跨域上传文件的方法
Nov 18 #Javascript
jQuery ajax 当async为false时解决同步操作失败的问题
Nov 18 #Javascript
微信小程序开发实战教程之手势解锁
Nov 18 #Javascript
You might like
帖几个PHP的无限分类实现想法~
2007/01/02 PHP
连接到txt文本的超链接,不直接打开而是点击后下载的处理方法
2009/07/01 PHP
服务器变量 $_SERVER 的深入解析
2013/07/02 PHP
PHP入门经历和学习过程分享
2014/04/11 PHP
PHP aes (ecb)解密后乱码问题
2015/06/22 PHP
php使用Imagick生成图片的方法
2015/07/31 PHP
PHP上传文件参考配置大文件上传
2015/12/16 PHP
orm获取关联表里的属性值
2016/04/17 PHP
基于thinkPHP框架实现留言板的方法
2016/10/17 PHP
基于thinkPHP3.2实现微信接入及查询token值的方法
2017/04/18 PHP
php微信公众号开发之校园图书馆
2018/10/20 PHP
PHP数字金额转换成中文大写显示
2019/01/05 PHP
PHP微信发送推送消息乱码的解决方法
2019/02/28 PHP
JQuery 小练习(实例代码)
2009/08/07 Javascript
jquery+ajax+C#实现无刷新操作数据库数据的简单实例
2014/02/08 Javascript
使用jQuery实现返回顶部
2015/01/26 Javascript
JavaScript实现上下浮动的窗口效果代码
2015/10/12 Javascript
DWR中各种java方法的调用
2016/05/04 Javascript
JS双击变input框批量修改内容
2016/12/12 Javascript
理顺8个版本vue的区别(小结)
2018/09/17 Javascript
js+html实现周岁年龄计算器
2019/06/25 Javascript
tensorflow识别自己手写数字
2018/03/14 Python
Python中对数组集进行按行打乱shuffle的方法
2018/11/08 Python
使用python将mysql数据库的数据转换为json数据的方法
2019/07/01 Python
python调用c++返回带成员指针的类指针实例
2019/12/12 Python
CSS3控制HTML元素动画效果
2014/02/08 HTML / CSS
详解FireFox下Canvas使用图像合成绘制SVG的Bug
2019/07/10 HTML / CSS
html5中valid、invalid、required的定义
2014/02/21 HTML / CSS
舒适的豪华鞋:Taryn Rose
2018/05/03 全球购物
中医药大学市场营销专业自荐信
2013/09/29 职场文书
中专三年学习的个人自我评价
2013/12/12 职场文书
4s店市场专员岗位职责
2014/04/09 职场文书
租房协议书怎么写
2014/04/10 职场文书
村居抓节水倡议书
2014/05/19 职场文书
2014年第四季度入党积极分子思想汇报(十八届四中全会)
2014/11/03 职场文书
golang 接口嵌套实现复用的操作
2021/04/29 Golang