欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

thinkphp ajaxfileupload實現(xiàn)異步上傳圖片的示例

 更新時間:2017年08月28日 10:35:11   作者:十里長亭  
本篇文章主要介紹了thinkphp ajaxfileupload實現(xiàn)異步上傳圖片的示例,具有一定的參考價值,有興趣的可以了解一下

thinkphp開發(fā)圖片上傳,圖片異步上傳是目前比較方便的功能,這里我就不寫css文件了,將代碼寫出來。引入核心文件下載https://github.com/carlcarl/A...

HTML

下面首先在html頁面引入相關(guān)js資源

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>圖片上傳</title> 
<script type="text/javascript" src="js/jquery-1.8.2.min.js"></script>
<script type="text/javascript" src="js/ajaxfileupload.js"></script> 
</head>
<body>
</body>
</html>

接下來在body中創(chuàng)建相關(guān)div

<label class="title w100">封面圖片:</label>
<div class="f_l">
 <label class="fileupload" onclick="upd_file(this,'image_file');">
  <input type="file" class="filebox" name="image_file" id="image_file"/>
  <!--上傳成功后圖片會給value賦值圖片路徑,以便于form表單提交數(shù)據(jù)-->
  <input type="hidden" name="image" value="">      
 </label>
 <label class="fileuploading hide" ></label>     
</div>
<div class="blank15"></div>
<!--上傳成功后圖片會在這里顯示否則是默認圖片-->
<img id="image" src="/Public/images/empty_thumb.gif" />

解釋一下:

其中upd_file(this,'image_file')不可缺少

其中隱藏的input 是用于上傳成功后賦值圖片路徑,以便于form表單提交數(shù)據(jù)

接下來在html中編輯javascript腳本以便于傳遞和提交圖片功能

<script>
function upd_file(obj,file_id){ 
$("input[name='"+file_id+"']").bind("change",function(){   
 $(obj).hide();
 $(obj).parent().find(".fileuploading").removeClass("hide");
 $(obj).parent().find(".fileuploading").removeClass("show");
 $(obj).parent().find(".fileuploading").addClass("show");
  $.ajaxFileUpload
  (
   {
    url:'/index.php/home/avatar/app_upload_image',//上傳圖片處理文件
    secureuri:false,
    fileElementId:file_id,
    dataType: 'json',
    success: function (data, status)
    {
      $(obj).show();
      $(obj).parent().find(".fileuploading").removeClass("hide");
     $(obj).parent().find(".fileuploading").removeClass("show");
     $(obj).parent().find(".fileuploading").addClass("hide");
      if(data.status==1)
      {
       $("#image").attr("src",data.thumb_url+"?r="+Math.random());        
       $("input[name='image']").val(data.url);//返回json后將隱藏input賦值
      //$("#img_url").html('<input type="hidden" name="img_url" value="'+ path.path +'" />');
      }
      else
      {
       $.showErr(data.msg);
      }
    },
    error: function (data, status, e)
    {
     $.showErr(data.responseText);;
     $(obj).show();
     $(obj).parent().find(".fileuploading").removeClass("hide");
     $(obj).parent().find(".fileuploading").removeClass("show");
     $(obj).parent().find(".fileuploading").addClass("hide");
    }
   }
  );
  $("input[name='"+file_id+"']").unbind("change");
}); 
}
<script>

thikphp 中創(chuàng)建方法 app_upload_image()

 function app_upload_image($maxSize=52428800){
  $id=session('id');
  $config=array(
   'rootPath' =>'Upload',   //文件上傳保存的根路徑
   'savePath' =>'/avatar/', 
   'exts'  => array('jpg', 'gif', 'png', 'jpeg','bmp'),
   'maxSize' => $maxSize,
   'autoSub' => true,
   );
  $upload = new \Think\Upload($config);// 實例化上傳類
  $z = $upload->uploadOne($_FILES['image_file']);
  if($z) {
  //拼接圖片的路徑名
    $img='/Upload'.$z['savepath'].$z['savename'];
    $_POST['image_file']=$img;
    //獲取上傳圖片絕對路徑
    $imgsrc=$_SERVER['DOCUMENT_ROOT'].__ROOT__.$_POST['image_file'];
    $image = new \Think\Image(); 
    $image->open($imgsrc);
    //將圖片裁剪為400x400并保存為corp.jpg
    $image->thumb(205, 160,\Think\Image::IMAGE_THUMB_CENTER)->save($imgsrc);

   $this->ajaxReturn(array("thumb_url"=>$img,"url"=>$img,"status"=>1));
  }
 }

OK這樣就好了,首先和大家說一下,如果ajaxfileupload.js報錯程序是不會跑通的,如果你的程序報錯就檢查你的ajaxfileupload文件是不是版本的問題

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • PHP+jQuery翻板抽獎功能實現(xiàn)

    PHP+jQuery翻板抽獎功能實現(xiàn)

    在電視節(jié)目中有一種抽獎形式暫且叫做翻板抽獎,臺上有一個墻面,墻面放置幾個大方塊,主持人或者抽獎?wù)叻_對應(yīng)的方塊即可揭曉中獎結(jié)果。類似的抽獎形式還可以應(yīng)用在WEB中,本文將使用PHP+jQuery為您講解如何實現(xiàn)翻板抽獎程序。
    2015-10-10
  • Yii2如何批量添加數(shù)據(jù)

    Yii2如何批量添加數(shù)據(jù)

    批量添加這個操作,在實際開發(fā)中經(jīng)常用得到,今天小編抽空給大家整理些有關(guān)yii2批量添加的問題,感興趣的朋友一起看看吧
    2016-05-05
  • CodeIgniter框架基本增刪改查操作示例

    CodeIgniter框架基本增刪改查操作示例

    這篇文章主要介紹了CodeIgniter框架基本增刪改查操作,結(jié)合具體實例形式分析了CodeIgniter框架針對數(shù)據(jù)庫進行創(chuàng)建、增刪改查等操作的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2017-03-03
  • PHP unlink與rmdir刪除目錄及目錄下所有文件實例代碼

    PHP unlink與rmdir刪除目錄及目錄下所有文件實例代碼

    這篇文章主要介紹了PHP unlink與rmdir刪除目錄及目錄下所有文件的實例代碼,需要的朋友可以參考下
    2018-02-02
  • Yii實現(xiàn)簡單分頁的方法

    Yii實現(xiàn)簡單分頁的方法

    這篇文章主要介紹了Yii實現(xiàn)簡單分頁的方法,涉及Yii模型調(diào)用讀取數(shù)據(jù)及視圖操作相關(guān)技巧,需要的朋友可以參考下
    2016-04-04
  • thinkphp的鉤子的兩種配置和兩種調(diào)用方法

    thinkphp的鉤子的兩種配置和兩種調(diào)用方法

    這篇文章主要介紹了thinkphp的鉤子的兩種配置和兩種調(diào)用方法,實例講解的很清晰,有不懂的同學(xué)可以學(xué)習(xí)下
    2021-02-02
  • Laravel中服務(wù)提供者和門面模式的入門介紹

    Laravel中服務(wù)提供者和門面模式的入門介紹

    這篇文章主要給大家介紹了關(guān)于Laravel中服務(wù)提供者和門面模式使用的相關(guān)資料,文中通過詳細的示例代碼給大家介紹了Laravel中的服務(wù)提供者和門面模式,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • ThinkPHP和UCenter接口沖突的解決方法

    ThinkPHP和UCenter接口沖突的解決方法

    這篇文章主要介紹了ThinkPHP和UCenter接口沖突的解決方法,分析了thinkPHP與UCenter接口沖突的原因及通過重命名解決沖突的相關(guān)操作步驟與實現(xiàn)技巧,需要的朋友可以參考下
    2016-07-07
  • tp5(thinkPHP5)框架數(shù)據(jù)庫Db增刪改查常見操作總結(jié)

    tp5(thinkPHP5)框架數(shù)據(jù)庫Db增刪改查常見操作總結(jié)

    這篇文章主要介紹了tp5(thinkPHP5)框架數(shù)據(jù)庫Db增刪改查常見操作,結(jié)合實例形式總結(jié)分析了thinkPHP5框架數(shù)據(jù)庫的增刪改查常見操作技巧與相關(guān)注意事項,需要的朋友可以參考下
    2019-01-01
  • 基于PHP字符串的比較函數(shù)strcmp()與strcasecmp()的使用詳解

    基于PHP字符串的比較函數(shù)strcmp()與strcasecmp()的使用詳解

    本篇文章是對PHP字符串的比較函數(shù)strcmp()與strcasecmp()的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05

最新評論