ThinkPHP5 通過ajax插入圖片并實時顯示(完整代碼)

單張圖片上傳

展示圖:

完整代碼:

<!doctype html>
<html>
 <head>
 <meta charset="utf-8">
 <title>ajax上傳圖片練習(xí)</title>
 <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
 <style type="text/css">
 </style>
 </head>
 <body>
 <form id="form">
 <label for="exampleinputemail1">身份證正面</label>
 <input type="file" id="drawing" name="drawing" onchange="picture(this);" />
 <!-- 上傳圖片的路徑 --><input type="hidden" name="" id="front" value="" />
 <div id="result"></div>
 </form>
 </body>
</html>
<script>
 //正面身份證
 function picture() {
 var data = new formdata($('#form')[0]);
 /* new formdata 的意思 
 * 獲取我們for表單中的所有input的name和value為了更方便傳值
 * https://segmentfault.com/a/1190000012327982?utm_source=tag-newest
 */
 console.log(data);
 $.ajax({
 url: "http://tp5-shopxo.likeball.top/index.php?s=/api/mi/measurement",
 type: 'post',
 data: data,
 datatype: 'json',
 cache: false,
 processdata: false,
 contenttype: false,
 success: function(data) {
 // console.log(data);
 if (data['whether']) {
  var result = '';
  var result1 = '';
  result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
  result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
  $('#results').html(result);
  $('#fronts').val(result1);
 }
 },
 error: function(data) {
 alert('錯誤');
 }
 });
 }
</script>

tp控制器代碼

public function measurement()
 { 
  $response = array(); 
  //這是身份證正面
  if ( isset( $_files['drawing'] ) && $_files['drawing']['error'] == 0 ) {
   $drawing = request()->file('drawing'); 
   $picture = $drawing->validate( ['ext'=>'jpg,png,gif'] )->move( root_path . 'static' . ds . 'upload/mi/img' );
  }
  if ( isset( $picture ) ) {
   $filepaths = '/static' . ds . 'upload/mi/img/'. $picture->getsavename();
   $response['whether'] = true;
   $response['site'] = $filepaths;
   echo json_encode($response); 
  }
  // 正面結(jié)束
 }

多個上傳

展示:

完整代碼:

<html>
 <head>
 <meta charset="utf-8">
 <title>文件上傳</title>
 <style type="text/css">
 #front {
 width: 120px;
 height: 120px;
 background-color: #8a6de9;
 }
 #frontage {
 width: 120px;
 height: 120px;
 background-color: #8a6de9;
 }
 #banking {
 width: 120px;
 height: 120px;
 background-color: #8a6de9;
 }
 #house {
 width: 120px;
 height: 120px;
 background-color: #8a6de9;
 }
 </style>
 <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
 </head>
 <body>
 <form id="uploadform">
 <!-- 1 -->
 <p>身份證正面:<input type="file" name="drawing" id="drawing" onchange="identity(this)" autocomplete="off" /></p>
 <input type="text" name="" id="fronts" value="" />
 <div id="front"></div>
 <!-- 1 -->
 <!-- 2 -->
 <p>身份證反面:<input type="file" name="reverse" id="reverse" onchange="card(this)" autocomplete="off" /></p>
 <input type="text" name="" id="frontages" value="" />
 <div id="frontage"></div>
 <!-- 2 -->
 <!-- 3 -->
 <p>銀行卡正面: <input type="file" name="transaction" id="transaction" onchange="obverse(this)" autocomplete="off" /></p>
 <input type="text" name="" id="bankings" value="" />
 <div id="banking"></div>
 <!-- 3 -->
 <!-- 4 -->
 <p>銀行卡反面: <input type="file" name="redlining" id="redlining" onchange="versa(this)" autocomplete="off" /></p>
 <input type="text" name="" id="houses" value="" />
 <div id="house"></div>
 <!-- 4 -->
 </form>
 </body>
</html>
<!-- 身份證正面 -->
<script type="text/javascript">
 function identity() {
 var formdata = new formdata();
 formdata.append("drawing", $('#drawing')[0].files[0]);
 // console.log(formdata);
 $.ajax({
 url: "http://tp5-shopxo.likeball.top/index.php?s=/api/mi/measurement",
 type: 'post',
 data: formdata,
 datatype: 'json',
 cache: false,
 processdata: false,
 contenttype: false,
 success: function(data) {
 console.log(data);
 if (data['whether'] == true) {
  var result = '';
  var result1 = '';
  result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
  result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
  $('#front').html(result);
  $('#fronts').val(result1);
 }
 },
 error: function(data) {
 console.log("錯誤");
 }
 });
 }
</script>
<!-- 身份證反面 -->
<script type="text/javascript">
 function card() {
 var formdata = new formdata();
 formdata.append("reverse", $('#reverse')[0].files[0]);
 // console.log(formdata);
 $.ajax({
 url: "http://tp5-shopxo.likeball.top/index.php?s=/api/mi/measurement",
 type: 'post',
 data: formdata,
 datatype: 'json',
 cache: false,
 processdata: false,
 contenttype: false,
 success: function(data) {
 console.log(data);
 if (data['whether'] == true) {
  var result = '';
  var result1 = '';
  result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
  result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
  $('#frontage').html(result);
  $('#frontages').val(result1);
 }
 },
 error: function(data) {
 console.log("錯誤");
 }
 });
 }
</script>
<!-- 銀行卡正面 -->
<script type="text/javascript">
 function obverse() {
 var formdata = new formdata();
 formdata.append("transaction", $('#transaction')[0].files[0]);
 // console.log(formdata);
 $.ajax({
 url: "http://tp5-shopxo.likeball.top/index.php?s=/api/mi/measurement",
 type: 'post',
 data: formdata,
 datatype: 'json',
 cache: false,
 processdata: false,
 contenttype: false,
 success: function(data) {
 console.log(data);
 if (data['whether'] == true) {
  var result = '';
  var result1 = '';
  result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
  result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
  $('#banking').html(result);
  $('#bankings').val(result1);
 }
 },
 error: function(data) {
 console.log("錯誤");
 }
 });
 }
</script>
<!-- 銀行卡反面 -->
<script type="text/javascript">
 function versa() {
 var formdata = new formdata();
 formdata.append("redlining", $('#redlining')[0].files[0]);
 // console.log(formdata);
 $.ajax({
 url: "http://tp5-shopxo.likeball.top/index.php?s=/api/mi/measurement",
 type: 'post',
 data: formdata,
 datatype: 'json',
 cache: false,
 processdata: false,
 contenttype: false,
 success: function(data) {
 console.log(data);
 if (data['whether'] == true) {
  var result = '';
  var result1 = '';
  result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
  result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
  $('#house').html(result);
  $('#houses').val(result1);
 }
 },
 error: function(data) {
 console.log("錯誤");
 }
 });
 }
</script>

tp控制器中

public function measurement()
 { 
  $response = array(); 
  //這是身份證正面
  if ( isset( $_files['drawing'] ) && $_files['drawing']['error'] == 0 ) {
   $drawing = request()->file('drawing'); 
   $picture = $drawing->validate( ['ext'=>'jpg,png,gif'] )->move( root_path . 'static' . ds . 'upload/mi/img' );
  }
  if ( isset( $picture ) ) {
   $filepaths = '/static' . ds . 'upload/mi/img/'. $picture->getsavename();
   $response['whether'] = true;
   $response['site'] = $filepaths;
   echo json_encode($response); 
  }
  // 正面結(jié)束
  // 這是反面
  if ( isset( $_files['reverse'] ) && $_files['reverse']['error'] == 0 ) {
   $reverse = request()->file('reverse'); 
   $reverse = $reverse->validate( ['ext'=>'jpg,png,gif'] )->move( root_path . 'static' . ds . 'upload/mi/img' );
  }
  if ( isset( $reverse ) ) {
   $contrary = '/static' . ds . 'upload/mi/img/'. $reverse->getsavename();
   $response['whether'] = true;
   $response['site'] = $contrary;
   echo json_encode($response); 
  }
  //銀行卡正面
  if ( isset( $_files['transaction'] ) && $_files['transaction']['error'] == 0 ) {
   $transaction = request()->file('transaction'); 
   $transaction = $transaction->validate( ['ext'=>'jpg,png,gif'] )->move( root_path . 'static' . ds . 'upload/mi/img' );
  }
  if ( isset( $transaction ) ) {
   $stuck = '/static' . ds . 'upload/mi/img/'. $transaction->getsavename();
   $response['whether'] = true;
   $response['site'] = $stuck;
   echo json_encode($response); 
  }
  //銀行卡反面
  if ( isset( $_files['redlining'] ) && $_files['redlining']['error'] == 0 ) {
   $redlining = request()->file('redlining'); 
   $redlining = $redlining->validate( ['ext'=>'jpg,png,gif'] )->move( root_path . 'static' . ds . 'upload/mi/img' );
  }
  if ( isset( $redlining ) ) {
   $other = '/static' . ds . 'upload/mi/img/'. $redlining->getsavename();
   $response['whether'] = true;
   $response['site'] = $other;
   echo json_encode($response); 
  }
 }

總結(jié)

以上所述是小編給大家介紹的thinkphp5 通過ajax插入圖片并實時顯示,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對碩編程網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频