AJAX2.0/express简述/CORS跨域/拖拽文件上传/multiple input的多文件上传属性

AJAX2.0

1.formdata:控制提交数据,文件上传;
2.cors:跨域

formdata 基础

    //formdata 常用的方法
    let data = new FormData();
    data.set(key,value)//设置一个key与value但是key重复的话value就会被覆盖
    data.append(key,value)//设置一个key与value,key重复的话value不会被覆盖
    data.get(key)
    data.getAll(key)//使用append设置后,需要使用getALL获取所有value
    data.delete(key)
    //使用formdata主要是用来上传文件,通常都是POST方法

formdata数据提交

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <script>
        window.onload=function (){
        let oUser=document.getElementById('user');
        let oPass=document.getElementById('pass');
        let oF=document.getElementById('f1');
        let oBtn=document.getElementById('btn1');
        //点击提交后创建FormData对象
        oBtn.onclick=function (){
            let data=new FormData();
            //设置普通数据的key与value
            data.set('user', oUser.value);
            data.set('pass', oPass.value);
            //文件数据使用循环append传到data中
            //oF.files是个伪数组,里面元素为上传的所有文件,
            Array.from(oF.files).forEach(file=>{
                data.append('f1', file);
            });

            //新建AJAX
            let oAjax=new XMLHttpRequest();

            //AJAX 提交POST请求,发送data到指定url,true为开启异步
            oAjax.open('POST', `http://localhost:8080/api`, true);
            oAjax.send(data);//发送数据
            //ajax回调函数
            oAjax.onreadystatechange=function (){
            if(oAjax.readyState==4){
                if(oAjax.status>=200 && oAjax.status<300 || oAjax.status==304){
                alert('成功');
                }else{
                alert('失败'); 
                }
            }
            };
        };
        };
        </script>
    </head>
    <body>
        用户:<input type="text" id="user" /><br>
        密码:<input type="password" id="pass" /><br>
        头像:<input type="file" id="f1" multiple /><br>//添加了multiple表明可以接受多个文件
        <input type="button" value="提交" id="btn1">
    </body>
    </html>

express库简述

安装express 
仍然是先初始化cnpm init -Y//-Y 初始化一切默认
然后安装 cnpm i express body-parser multer -D//安装两个模块

使用express写服务器端接收AJAX提交的FormData数据

    const express = require('express');//主体
    const body = require('body-parser');//用来接收普通POST数据,中间件
    const multer = require('multer');//用来接收文件POST数据,中间件

    let server = express();
    server.listen(8087);

    //express的中间件机制,需要把中间件加到服务上
    server.use(body.urlencoded({extended:false}));//body-parser中间件加到服务器
    let multerObj = multer({dest:'./file/'});//文件接收后放置的路标
    server.use(multerObj.any());//将multer加到服务器上,any()声明允许接收所有文件

    server.get('/',(req,res)=>{
        res.send();//发送响应数据,无需使用end.
    })//get方式请求该路径,执行此函数
    server.post('/api',(req,res)=>{
        //跨域 允许文件路径与localhost访问
        if(req.headers['origin']=='null' || req.headers['origin'].startsWith('http://localhost')){
            res.setHeader('Access-Control-Allow-Origin', '*');//设置允许跨域
        }
        res.send("OK");
        console.log(req.body);   //普通POST数据body-parser带来的body
        console.log(req.files);  //文件POST数据multer带来的files
    })//POST方式请求api路径,执行此函数
    server.use('/',(req,res)=>{
    })//所有的方式请求路径,都执行此函数

    //express自带的中间件,用来实现请求指定文件夹路下的径静态资源
    //代替了原生node中我们需要使用fs模块去指定路径下文件的功能。
    //开启服务器后,直接使用localhost:8087/文件名,即可自动去指定的(此处是www)下访问该文件
    server.use(express.static('./www/'));    

跨域CORS

服务器端设置一个响应头 Access-Control-Allow-Origin
res.setHeader('Access-Control-Allow-Origin','*')//*代表一切跨域行为都允许
浏览器发送的req头中有origin其中包含访问的域名(如果是文件域就是null),
对该属性的值进行判断,即可实现指定域名的跨域.使用req.headers['origin']来获得该值

拖拽上传文件

事件:
ondragenter 拖动进入事件
ondragleave 拖动离开事件
ondragover  拖动悬停事件//在此事件中需要阻止默认事件,ondrop事件才会发生
let oDiv = document.getElementById('div');
oDiv.ondrop = function(ev){
    console.log(ev.dataTransfer.files);//上传的文件列表,循环遍历append到formdata对象中即可.
} //拖动松开事件,此事件也需要阻止默认事件,否则浏览器会打开拖拽的文件,

扩展

H5扩展了input type='file'的多个文件上传
    <input type='file' id='f1' multiple>//添加了multiple表明可以接受多个文件
    var f1 = document.getElementById('f1');
    f1.files //即可获取所有的文件

跨域本不存在
    跨域是浏览器的阻止行为导致的,服务器依然可以收到数据(QAQ 好特么神奇);
    并且数据成功返回,只是浏览器没有显示出来.
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352