Ajax上傳圖片的本質_AJAX相關

來源:互聯網
上載者:User

1.圖片上傳到伺服器。

2.後台將圖片地址傳到html頁面,以圖片形式展現。

3.後天將圖片地址加入到input表單中,表單處於隱藏狀態。

4.前端刪除圖片,通過js操作,移除圖片與表單資料。

5.圖片上傳表單,是單獨的。不能嵌套在總的表單中。

6.牛逼的圖片上傳,可以對圖片進行處理。壓縮,加浮水印等。

7.點擊btn,觸發圖片點擊,圖片改變之後,觸發圖片表單提交。

點擊按鈕

<div id="up_status" style="display:none">[站外圖片上傳中……(2)]</div><div id="up_btn" class="carousel-btn"><span>添加圖片</span> </div><div id="carousel-preview"></div>

上傳表單

<form id="imageform" class="hidden" method="post" enctype="multipart/form-data" action="{sh::U('Goods/carouselUpload')}"><input id="carousel-photoimg" type="file" name="photoimg"></form>

觸發事件

$("#up_btn").click(function () {$("#carousel-photoimg").click();});$('#carousel-photoimg').on('change', function(){var status = $("#up_status");var btn = $("#up_btn");$("#imageform").ajaxForm({target: '#carousel-preview', beforeSubmit:function(){ // 提交前,用載入的圖片顯示status.show();btn.hide();}, success:function(){ // 提交後,載入的圖片顯示status.hide();btn.show();}, error:function(){status.hide();btn.show();} }).submit();});

後端驗證與處理

function carouselUpload() {$path = "Uploads/Store/goods/".date("Ymd").'/';if (!file_exists($path)) {mkdir($path, 0777, true);}$extArr = array("jpg", "png", "gif","jpeg");if(isset($_POST) and $_SERVER['REQUEST_METHOD'] == "POST"){$name = $_FILES['photoimg']['name'];$size = $_FILES['photoimg']['size'];if(empty($name)){echo '請選擇要上傳的圖片';exit;}$ext = $this->extend($name);if(!in_array($ext,$extArr)){echo '圖片格式錯誤!';exit;}if($size>(2000*1024)){echo '圖片大小不能超過2M';exit;}$image_name = time().rand(100,999).".".$ext;$tmp = $_FILES['photoimg']['tmp_name'];if(move_uploaded_file($tmp, $path.$image_name)){echo '<div class="carousel-container" onclick="deleteImg(this);">[站外圖片上傳中……(3)]<input name="goodsimg[]" value="'.$path.$image_name.'" type="hidden">[站外圖片上傳中……(4)]</div>';}else{echo '上傳出錯了!';}exit;}exit;}function extend($file_name){$extend = pathinfo($file_name);$extend = strtolower($extend["extension"]);return $extend;}

刪除圖片檔案

function deleteImg(obj) {$(obj).remove();// ajax 刪除圖片檔案var src = $(obj).data('src');$.ajax({type: "POST",url: "{sh::U('Goods/deleteImg')}",data: "src="+src,success: function(msg){}});}// 刪除圖片,避免造成空間不足public function deleteImg() {if (IS_AJAX) {$src = $this->_post('src');if(!unlink($src)){echo "檔案{$src}刪除失敗";}else{echo "檔案{$src}刪除成功";}}}

以上內容是小編給大家介紹的Ajax上傳圖片的本質的相關資料,希望對大家以上協助!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.