此篇記錄如何使用ajax進行頭像的更換,使用ajax須要引入一個jQuery的插件 jQuery form,在app.blade.php中引入:php
<link rel="stylesheet" href="/css/bootstrap.css"> {{--引入fontawesome--}} <link rel="stylesheet" href="/css/font-awesome.css"> <link rel="stylesheet" href="/css/style.css"> {{--引入jQueryform插件--}} <script src="/js/jquery-2.1.4.min.js"></script> <script src="/js/bootstrap.min.js"></script> <script src="https://cdn.bootcss.com/jquery.form/4.2.1/jquery.form.js"></script>
引入插件後對avatar.blade.php的前端頁面進行修改:css
<div class="container"> <div class="row"> <div class="col-md-6 col-md-offset-3"> <div class="text-center"> <div id="validation-errors"></div> <img src="{{Auth::user()->avatar}}" width="120" class="img-circle" id="user-avatar" alt=""> {!! Form::open(['method' => 'post', 'url'=>'user/avatar','id'=>'avatar','files'=>true]) !!} <div class="text-center"> <button type="button" class="btn btn-success avatar-button" id="upload-avatar">上傳新的頭像</button> </div> {!! Form::file('avatar',['class'=>'avatar','id'=>'image']) !!} <!-- 提交 --> {!! Form::close() !!} <div class="span5"> <div id="output" style="display:none"> </div> </div> {{--{!! Form::open(['method'=>'post','url'=>'user/avatar','files'=>true]) !!}--}} {{--Avatar 上傳--}} {{--{!! Form::file('avatar') !!}--}} {{--<!-- 提交 -->--}} {{--{!! Form::submit('tijao',['class' => 'btn btn-primary form-control']) !!}--}} {{--{!! Form::close() !!}--}} </div> </div> @if($errors->any()) <ul class="list-group"> @foreach($errors->all() as $error) <li class="list-group-item list-group-item-danger">{{ $error }}</li> @endforeach </ul> @endif </div> </div>
而後寫js代碼:html
<script> $(document).ready(function() { var options = { beforeSubmit: showRequest, success: showResponse, dataType: 'json' }; $('#image').on('change', function(){ $('#upload-avatar').html('正在上傳...'); $('#avatar').ajaxForm(options).submit(); }); }); function showRequest() { $("#validation-errors").hide().empty(); $("#output").css('display','none'); return true; } function showResponse(response) { if(response.success == false) { var responseErrors = response.errors; $.each(responseErrors, function(index, value) { if (value.length != 0) { $("#validation-errors").append('<div class="alert alert-error"><strong>'+ value +'</strong><div>'); } }); $("#validation-errors").show(); } else { $('#user-avatar').attr('src',response.avatar); $('#upload-avatar').html('更換新的頭像'); } } </script>
前端的工做到此爲止,咱們來處理後臺的業務邏輯:前端
public function changeAvatar(Request $request)
{
// 聲明路徑名
$destinationPath = 'uploads/';
// 取到圖片
$file = $request->file('avatar');
$input = array('image' => $file);
$rules = array(
'image' => 'image'
);
$validator = \Validator::make($input, $rules);
if ( $validator->fails() ) {
return \Response::json([
'success' => false,
'errors' => $validator->getMessageBag()->toArray()
]);
}
// 得到圖片的名稱 爲了保證不重複 咱們加上userid和time
$file_name = \Auth::user()->id . '_' . time() . $file->getClientOriginalName();
// 執行move方法
$file->move($destinationPath, $file_name);
// 裁剪圖片 生成200x200的縮略圖
Image::make($destinationPath . $file_name)->fit(200)->save();
// 保存到User
$user = User::findOrFail(\Auth::user()->id);
$user->avatar = '/' . $destinationPath . $file_name;
$user->save();
return \Response::json([
'success' => true,
'avatar' => asset($destinationPath.$file_name),
]);
}
注意這裏返回的是json文件jquery