Để tạo một ứng dụng giỏ hàng sử dụng Vue.js, bạn cần tạo một ứng dụng Vue mới và triển khai các tính năng cơ bản của giỏ hàng. Dưới đây là hướng dẫn cơ bản để bạn bắt đầu:

Bước 1: Tạo dự án Vue

Đảm bảo bạn đã cài đặt Node.js và Vue CLI trên máy tính của bạn.

Mở Command Prompt hoặc Terminal và tạo một dự án Vue mới bằng cách chạy lệnh sau:

vue create gio-hang

Chọn các cài đặt mặc định hoặc tùy chỉnh theo nhu cầu của bạn khi tạo dự án Vue.

Bước 2: Tạo các thành phần Vue

Trong dự án Vue của bạn, tạo các thành phần Vue cơ bản để đại diện cho giỏ hàng, sản phẩm và danh sách sản phẩm.

<!-- GioHang.vue -->
<template>
  <div>
    <h2>Giỏ hàng</h2>
    <ul>
      <li v-for="item in cartItems" :key="item.id">
        {{ item.name }} - {{ item.price }} đồng
      </li>
    </ul>
    <p>Tổng cộng: {{ total }} đồng</p>
  </div>
</template>

<script>
export default {
  computed: {
    cartItems() {
      // Trả về danh sách các sản phẩm trong giỏ hàng
      return this.$store.state.cartItems;
    },
    total() {
      // Tính tổng giá trị các sản phẩm trong giỏ hàng
      return this.cartItems.reduce((total, item) => total + item.price, 0);
    },
  },
};
</script>

Bước 3: Quản lý dữ liệu với Vuex

Tạo một Vuex store để quản lý trạng thái giỏ hàng và các hành động liên quan đến giỏ hàng.

// Trong store/index.js
import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

export default new Vuex.Store({
  state: {
    cartItems: [],
  },
  mutations: {
    addToCart(state, product) {
      state.cartItems.push(product);
    },
    clearCart(state) {
      state.cartItems = [];
    },
  },
  actions: {
    addToCart({ commit }, product) {
      commit('addToCart', product);
    },
    clearCart({ commit }) {
      commit('clearCart');
    },
  },
});

Bước 4: Tích hợp giỏ hàng vào ứng dụng Vue

Trong file main.js, nhập Vuex store và sử dụng nó để chia sẻ dữ liệu giỏ hàng với toàn bộ ứng dụng.

// Trong main.js
import Vue from 'vue';
import App from './App.vue';
import store from './store';

Vue.config.productionTip = false;

new Vue({
  store,
  render: (h) => h(App),
}).$mount('#app');

Bước 5: Sử dụng thành phần Giỏ hàng trong ứng dụng Vue

Trong file App.vue, sử dụng thành phần Giỏ hàng để hiển thị giỏ hàng.

<template>
  <div id="app">
    <h1>Ứng dụng Giỏ hàng Vue</h1>
    <GioHang />
  </div>
</template>

<script>
import GioHang from './components/GioHang';

export default {
  components: {
    GioHang,
  },
};
</script>

Bước 6: Tích hợp sản phẩm và chức năng thêm vào giỏ hàng

Trong trang sản phẩm hoặc danh sách sản phẩm của bạn, sử dụng các nút hoặc sự kiện để thêm sản phẩm vào giỏ hàng thông qua Vuex store.

<template>
  <div>
    <h2>Danh sách sản phẩm</h2>
    <ul>
      <li v-for="product in products" :key="product.id">
        {{ product.name }} - {{ product.price }} đồng
        <button @click="addToCart(product)">Thêm vào giỏ hàng</button>
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      products: [
        { id: 1, name: 'Sản phẩm 1', price: 100000 },
        { id: 2, name: 'Sản phẩm 2', price: 200000 },
        // Thêm sản phẩm khác tùy ý
      ],
    };
  },
  methods: {
    addToCart(product) {
      this.$store.dispatch('addToCart', product);
    },
  },
};
</script>

Đây chỉ là một cách cơ bản để tạo một ứng dụng giỏ hàng sử dụng Vue.js. Bạn có thể mở rộng và tùy chỉnh chức năng theo ý muốn, bao gồm thêm tính năng xóa sản phẩm khỏi giỏ hàng, tăng/giảm số lượng sản phẩm, tính tổng giá trị giỏ hàng…

  • Vue Js
  • July 24, 2023
  • 0 comment
  • 282 views

Recent posts

iPhone sẽ bị ‘vứt xó’ trong những năm tới, nhường bước cho các công nghệ mới

iPhone sẽ bị ‘vứt xó’ trong những năm tới, nhường bước cho các công nghệ mới

Những chiếc iPhone đã sống đủ lâu với ngôi vị quán quân di động, đã đến lúc sẽ có công […]

[WordPress] Hướng dẫn tạo Custom Action Hook trong WordPress

[WordPress] Hướng dẫn tạo Custom Action Hook trong WordPress

Tạo custom Action Hook trong WordPress là một kỹ năng rất hữu ích để tùy chỉnh và mở rộng chức […]

Cuộc chiến không hồi kết: “Trình duyệt CC” chặn quảng cáo

Cuộc chiến không hồi kết: “Trình duyệt CC” chặn quảng cáo

Người dùng internet không còn lạ lẫm gì trước những “chiêu” được “hãng Y” sử dụng, nhằm hạn chế việc […]

Windows có lỗ hổng nghiêm trọng, Microsoft biết nhưng từ chối sửa

Windows có lỗ hổng nghiêm trọng, Microsoft biết nhưng từ chối sửa

Một lỗ hổng bảo mật trên Windows có “cửa hậu” cho phép đăng nhập bằng mật khẩu cũ. Một phát […]

Apple phát hành iOS 18.5 RC: Sắp ra mắt chính thức?

Apple phát hành iOS 18.5 RC: Sắp ra mắt chính thức?

Apple phát hành phiên bản Release Candidate (RC) của iOS 18.5 và iPadOS 18.5 đến các nhà phát triển cũng như người dùng tham gia […]

© 2021 Tạp Chí CNTT. Mr Hoang