laravel 怎麼使用ajax

  1. HTML blade部分
    php

    <meta name="_token" content="{{ csrf_token() }}"/>
  2. 前端js請求部分(注意那個header屬性,是爲了不跨站僞造請求攻擊寫的)
    前端

    $.ajax({
    type: 'POST',
    url: '/ajax/create',
    data: { date : '2015-03-12'},
    dataType: 'json',
    headers: {
    'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content')
    },
    success: function(data){
    console.log(data.status);
    },
    error: function(xhr, type){
    alert('Ajax error!')
    }
    });
  3. 路由部分route.php(ajax/create路由打到Controllers/Ajax/PollController.php的store方法上處理)ajax


Route::group(['prefix' => 'ajax', 'namespace' => 'Ajax'], function(){
Route::post('create', 'PollController@store');
});


  1. 控制器方法PollController.php,json


<?php namespace App\Http\Controllers\Ajax;

use App\Http\Requests;
use App\Http\Controllers\Controller;

use Illuminate\Http\Request;
use Illuminate\Http\Response;
use App\Poll;  // 用數據模型

use Redirect, Input, Auth, Log;

class PollController extends Controller {
public function store(Request $request)
{
    $poll = new Poll;

    $poll->date = Input::get('date');

    if ($poll->save()) {
        return response()->json(array(
            'status' => 1
            'msg' => 'ok',
        ));
    } else {
        return Redirect::back()->withInput()->withErrors('保存失敗!');
    }
}
}