backbonejs上传文件

1 篇文章 0 订阅
0 篇文章 0 订阅

2017年了,转眼就30岁了,时间真TM快。

纵观这一年的改变,在得知跟自己相亲的人突然嫁给别人时,如五雷轰顶,咬牙离开了原来的地方,自己找了个单间住下,又咬牙决定学车,恰巧在年前无法考试。

我心态的变化就是更加包容,更加阳光了,只是找不到对象。年年为这事发愁。

        好了,心声说完,开始说正事。

============================我是正经的分割线=========================================

        如果用表单提交数据,我们往往使用$('#postForm').serialize()$('#postForm').serializeArray()来获取序列化数据。

     $.ajax({
     	url : "http://localhost:8080/STS/rest/user",
     	type : "POST",
     	data : $( '#postForm').serialize(),
     	success : function(data) {
          $( '#serverResponse').html(data);
     	},
     	error : function(data) {
          $( '#serverResponse').html(data.status + " : " + data.statusText + " : " + data.responseText);
     	}
     });

不过,上传文件时,file无法通过序列化来获取。

        可以使用html5的FormData:  var post_data = new FormData();,需要注意的是FormData是XMLHttpRequest Level 2的新特性,jquery1.X的版本不支持。

        ===========================================可以开始了==============================================================

        模板index.html

	<form role="form" id="import-excel-form" enctype="multipart/form-data">
            <div class="form-group">
                <label for="template_type">选择设备分类:</label>
                <input type="input" id="template_type" />
            </div>
            <div class="form-group">
                <label for="excel_file">选择文件:</label>
                <input type="file" name="excel_file" class="form-control"  id="excel_file" />
            </div>
            <div class="form-group">
                <input type="button" class="btn btn-primary" id="btn-import-excel"  value="上传"/>
            </div>
        </form>

  上面非常重要的是enctype="multipart/form-data",


js处理文件上传 

	    var file_data = new FormData();
            var upload_form = $(e.currentTarget).closest("form");
            var template_type = $(upload_form).find("#template_type").val();
            var excel_file = $("#excel_file")[0].files.item(0);
            file_data.append("data", JSON.stringify({"template_type":template_type}));
            file_data.append("file", excel_file);
            var new_model = new CommonModel();      //这里你需要导入一个已经写好的model,不清楚的自己看看backbonejs教程        
            new_model.url = this.collection.url;
            new_model.save(null, {data:file_data, contentType:false, processData:false, success:function (model, response) {
                console.log(response);
            }})

         django处理请求

         django的request接受的方式有request.POST, request.read(), request.FILES。

         上段代码的参数,"template_type"需要request.read()读取,"file"需要request.FILES读取。

         具体代码就不写了。

         ==========================================其实已经完了===================================================

         那段backbonejs处理参数的代码,是封装了ajax的方法,如果用原生的ajax,我提供一个例子,只是例子,

        

     $.ajax({  
          url: 'http://localhost:8080/cfJAX_RS/rest/file/upload' ,  
          type: 'POST',  
          data: formData,  
          async: false,  
          cache: false,  
          contentType: false,  
          processData: false,  
          success: function (returndata) {  
              alert(returndata);  
          },  
          error: function (returndata) {  
              alert(returndata);  
          }  
     });  

        

---------------- backbone开发经典 336页清晰完整版pdf-------------- 内容简介 · · · · · · backbone.js提供了一套web开发的框架,为复杂javascript应用程序提供一个mvc结构。 《backbone.js应用程序开发》详细介绍了如何使用backbone.js完成web应用开发。全书从了解mvc、spa和backbone.js的基本知识开始,然后着手构建3个示例应用程序;此外,backbone和grunt-bbb、jquery mobile等开发工具的配合使用,以及jasmine、qunit和sinonjs等测试解决方案。 本书的作者是知名的javascript专家、谷歌chrome团队的工程师addy osmani。本书适合于javascript程序员、web开发人员,尤其是想要学习和使用backbone.js的读者阅读参考。 如果你想使用单页应用程序(spa)模型创建前端站点,本书向你展示了如何使用backbone.js完成这类工作。你将学会使用backbone自有风格的模型-视图-控制器(mvc)架构,来创建结构化的javascript应用程序。 《backbone.js应用程序开发》先从了解mvc、spa和backbone的基本知识开始,然后着手构建示例应用程序——一个简单的todo列表应用程序、restful风格的图书应用程序、以及使用backbone和requirejs的模块化应用程序。本书的作者是谷歌chrome团队的工程师addy osmani,他还演示了框架的高级应用。 《backbone.js应用程序开发》包括以下内容: 了解backbone.js如何给客户端带来mvc方面的好处; 编写易于阅读的、结构化的和易扩展代码 ; 使用backbone.marionette和thorax扩展框架; 解决使用backbone.js时会遇到的常见问题; 使用amd和requirejs将代码进行模块化组织; 使用backbone.paginator插件为collections数据分页; 使用样板代码引导新的backbone.js应用程序; 使用jquery mobile,并解决两者之间的路由问题; 使用jasmine、qunit和sinonjs对backbone应用进行单元测试。 作者简介 · · · · · · Addy Osmani,本书的作者是知名的JavaScript专家、谷歌Chrome团队的工程师,他对JavaScript应用程序架构有着强烈的爱好,还创建了一些比较流行的项目,如TodoMVC,并且对Yeoman、Modernizr和jQuery等其他开源项目也有重要贡献。除此之外,Addy Osmani也是一位高产的博主(http://addyosmani.com/blog),同时也是O'reilly出版的《JavaScript设计模式》一书的作者。 徐涛(网名:汤姆大叔;微博:@TomXuTao),微软最有价值专家(MVP)、项目经理、软件架构师,擅长大型互联网产品的架构与设计,崇尚敏捷开发模式,熟悉设计模式、前端技术、以及各种开源产品,曾获MCP、MCSE、MCDBA、MCTS、MCITP、MCPD、PMP认证。《JavaScript编程精解》、《JavaScript启示录》译者,博客地址:Http://www.cnblogs.com/TomXu。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值