+2

Xây dựng ứng dựng SPA với laravel

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.vuenhư 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

Đăng nhập để bình luận
Avatar
@phamduchuy552
thg 12 17, 2021 10:27 SA

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))

Avatar
+2
Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí