国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

JS+php后臺實(shí)現(xiàn)文件上傳功能詳解

2024-05-06 16:48:39
字體:
供稿:網(wǎng)友

本文實(shí)例講述了JS+php后臺實(shí)現(xiàn)文件上傳功能。分享給大家供大家參考,具體如下:

一、利用 FormData 對象形式上傳

FormData 是 XMLHttpRequest 2 的產(chǎn)物,兼容 IE10+。

FormData 對象,可以把form中所有表單元素的name與value組成一個(gè)queryString,提交到后臺。在使用Ajax提交時(shí),使用FormData對象可以減少拼接queryString的工作量。

使用 FormData 對象

1.取得form對象,作為參數(shù)傳入到FormData對象

html:

<form name="form1" id="form1">   <input type="text" name="name" value="fdipzone">   <input type="text" name="gender" value="male"></form>

js:

var form = document.getElementById('form1');var formdata = new FormData(form);

2.創(chuàng)建一個(gè)FormData空對象,然后使用append方法添加key/value

var formdata = new FormData();formdata.append('name','fdipzone');formdata.append('gender','male');

使用FormData提交表單及上傳文件實(shí)例:

實(shí)例1

一般項(xiàng)目中使用的點(diǎn)擊上傳文件的按鈕跟 <input type="file"/> 默認(rèn)樣式是不一樣的,我們得自定義。方法是,自己寫一個(gè)<button> 按鈕,然后再寫一個(gè) <input type="file"/>(這個(gè)要隱藏,太難看),點(diǎn)擊 <button> 的時(shí)候出發(fā) <input type="file"/> 的 click 事件。

HTML:

<input type="file"    :style="{display: 'none'}"    ref="input" @change="selectedFile"/><button @click="upload">上傳</button>

JS:

methods: {  triggerSelect () {   this.$refs.input.click()  },  selectedFile (e) {   console.log(e.target.files[0])   //根據(jù)項(xiàng)目需求做具體處理,比如說獲取文件名  },  async upload () {   //如果不需要用到上傳后的返回值可以把 async...await 語法去掉   let files = this.$refs.input.files;   if(files.length > 0) {    let form = new FormData();    form.append('file', files[0])    let data = await new Promise((resolve, reject) => {      axios({       url: '',       method: 'post',       data: form      })       .then(res => {        resolve(res)       })       .catch(err => {        reject(err)       })     })   }  }}

實(shí)例2

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title> FormData Demo </title> </head> <body>  <form name="form1" id="form1">    <p>name:<input type="text" name="name" ></p>    <p>gender:<input type="radio" name="gender" value="1">male <input type="radio" name="gender" value="2">female</p>    <p>photo:<input type="file" name="photo" id="photo"></p>    <p><input type="button" name="b1" value="submit" onclick="fsubmit()"></p>  </form>  <div id="result"></div> <script src="//code.jquery.com/jquery-1.11.0.min.js"></script> <script type="text/javascript">  function fsubmit(){    var data = new FormData($('#form1')[0]);    $.ajax({      url: 'server.php',      type: 'POST',      data: data,      dataType: 'JSON',      cache: false,      processData: false, //不處理發(fā)送的數(shù)據(jù),因?yàn)閐ata值是FormData對象,不需要對數(shù)據(jù)做處理      contentType: false  //不設(shè)置Content-type請求頭    }).done(function(ret){      if(ret['isSuccess']){        var result = '';        result += 'name=' + ret['name'] + '<br>';        result += 'gender=' + ret['gender'] + '<br>';        result += '<img src="' + ret['photo'] + '" width="100">';        $('#result').html(result);      }else{        alert('提交失敗');      }    });    return false;  } </script></body></html>

server.php

<?php$name = isset($_POST['name'])? $_POST['name'] : '';$gender = isset($_POST['gender'])? $_POST['gender'] : '';$filename = time().substr($_FILES['photo']['name'], strrpos($_FILES['photo']['name'],'.'));$response = array();if(move_uploaded_file($_FILES['photo']['tmp_name'], $filename)){  $response['isSuccess'] = true;  $response['name'] = $name;  $response['gender'] = $gender;  $response['photo'] = $filename;}else{  $response['isSuccess'] = false;}echo json_encode($response);?>

帶顯示圖片的上傳圖片

// -------- 將以base64的圖片url數(shù)據(jù)轉(zhuǎn)換為Blob --------function convertBase64UrlToBlob(urlData, filetype){    //去掉url的頭,并轉(zhuǎn)換為byte    var bytes = window.atob(urlData.split(',')[1]);    //處理異常,將ascii碼小于0的轉(zhuǎn)換為大于0    var ab = new ArrayBuffer(bytes.length);    var ia = new Uint8Array(ab);    var i;    for (i = 0; i < bytes.length; i++) {      ia[i] = bytes.charCodeAt(i);    }    return new Blob([ab], {type : filetype});}$input.on('change', function (e) {    var input = $input.get(0);    var files = input.files || [];    if (files.length === 0) {      return;    }    console.log('選中 ' + files.length + ' 個(gè)文件');    // 遍歷選中的文件,預(yù)覽、上傳    $.each(files, function (key, file) {      var filename = file.name || '';      var fileType = file.type || '';      var reader = new FileReader();      // onload事件      reader.onload = function (e) {        var base64 = e.target.result || this.result;        var formData = new FormData();        formData.append("upload_file", convertBase64UrlToBlob(base64, fileType), filename);        var xhr = new XMLHttpRequest();        // 開始上傳        xhr.open('POST', uploadImgUrl, true);        // 發(fā)送數(shù)據(jù)        xhr.send(formData);      });      reader.readAsDataURL(file);    });});

二、base64 字符串方式上傳圖片

DataURI 允許在HTML文檔中嵌入小文件,可以使用 img 標(biāo)簽或 CSS 嵌入轉(zhuǎn)換后的 Base64 編碼,減少 HTTP 請求,加快小圖像的加載時(shí)間。 經(jīng)過Base64 編碼后的文件體積一般比源文件大 30% 左右。

Base64 在CSS中的使用:

.box{ background-image: url("...");}

Base64 在HTML中的使用:

<img src="..." />

不推薦用base64,效率慢,消耗流量,占用空間。推薦使用把base64圖片格式轉(zhuǎn)換成FormData形式傳遞

希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。


注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 西乌珠穆沁旗| 武城县| 安福县| 黄浦区| 徐水县| 神农架林区| 琼结县| 治多县| 隆安县| 上林县| 延寿县| 方山县| 湘阴县| 凤阳县| 汽车| 苍南县| 哈密市| 张家川| 淮北市| 青海省| 锡林浩特市| 布尔津县| 社旗县| 峨眉山市| 陇南市| 重庆市| 洪江市| 南川市| 保康县| 鹰潭市| 永仁县| 佛学| 江西省| 平武县| 安宁市| 濮阳县| 肇州县| 正阳县| 海晏县| 通河县| 锦屏县|