Xây dựng ứng dựng SPA với laravel
Bài đăng này đã không được cập nhật trong 5 năm
Hôm nay mình xin giới thiệu với các bạn làm sao để kết kợp nuxt js và laravel với nhau để xây dựng ứng dụng Single Page Application (SPA).
Cài đặt
Laravel
Giả xử các bạn đã có sẵn các package để chạy với laravel rồi: init project laravel bằng lệnh sau:
composer create-project laravel/laravel spa
vào thư mục spa để cài đặt package laravel-nuxt
, package này sẽ cho phép bạn call url mà ko bị laravel trả ra 404
cd spa
composer require pallares/laravel-nuxt
packages này sẽ được tự động load vào server provider của laravel (>=5.5). Nếu bạn sử dựng phiên bản laravel thấp hơn thì cần thêm nó vào config config/app.php
:
'providers' => [
// ...
Pallares\LaravelNuxt\LaravelNuxtServiceProvider::class,
],
thay đổi file web.php như sau, để tránh việc laravel trả ra 404 pages:
<?php
Route::get(
'{uri}',
'\\'.Pallares\LaravelNuxt\Controllers\NuxtController::class
)->where('uri', '.*');
Cài đặt laravel-nuxt (for JS)
Xóa toàn bộ nội dung có trong file package.json
thêm nội dung sau vào:
{
"private": true,
"scripts": {
"start": "laravel-nuxt dev",
"build": "laravel-nuxt build"
},
"dependencies": {
"laravel-nuxt": "^1.0.0"
}
}
sau đó chạy lệnh sau để lấy dữ liệu về:
npm install
laravel-nuxt
sẽ cài đặt toàn bộ những packages cần thiếu cho nuxt js bao gồm Vue
, vue-router
, @nuxtjs/axios
...
Tạo file nuxt.config.js
trong thư mục gốc với nội dung như sau:
const laravelNuxt = require("laravel-nuxt");
module.exports = laravelNuxt({
modules: [],
plugins: [],
});
từ bây nuxt sẽ chạy trong thư mục sau: resources/nuxt
develop
Tạo một static page
tạo file index.vue trong thư mục sau: resources/nuxt/pages/index.vue
// resources/nuxt/pages/index.vue
<template>
<h1>Hello {{ name }}!</h1>
</template>
<script>
export default {
data: () => {
return { name: 'viblo' };
},
};
</script>
Khởi tạo server nuxt bằng lệnh sau:
npm start hoặc
laravel-nuxt dev
vào http://localhost:8000
bạn sẽ thấy kết quả
call api với axios (SPA)
viết 1 api đơn giản như sau trong file routes/api.php
Route::get('me', function () {
return [
'name' => 'Viblo api',
];
});
thay đổi nội dung file resources/nuxt/pages/index.vue
như sau:
<template>
<h1>Hello {{ user.name }}!</h1>
</template>
<script>
export default {
// https://github.com/nuxt-community/axios-module
async asyncData({ app }) {
const user = await app.$axios.$get('api/me');
return { user };
},
};
</script>
khởi tạo server laravel với lệnh sau:
php artisan serve
sau đó vào localhost:8000 sẽ thấy đoạn Hello John Doe
Deploy
để deploy code lên server bạn cần buil nuxt js với lệnh sau:
npm run build hoặc
laravel-nuxt build
Tham khảo
All rights reserved
Bình luận
It's not working for me. When I run npm start and open localhost:8000, it shows Error occured while trying to proxy to: 127.0.0.1:8000/ . There was no other process that occupying that port. What could be the problem? ([HPM] Error occurred while trying to proxy request /favicon.ico from 127.0.0.1:8000 to http://127.0.0.1:8001 (ECONNREFUSED) (https://nodejs.org/api/errors.html#errors_common_system_errors))