PHP und Vue: Erkennen Sie die Funktion des Austauschs von Mitgliedspunkten und Geschenken.
Die meisten Online-Einkaufszentren bieten ein Mitgliedspunktesystem an, um Benutzer anzulocken. Eine Möglichkeit, Mitgliedspunkte zu verwenden, besteht darin, sie gegen Geschenke einzutauschen. In diesem Artikel stellen wir vor, wie Sie mit PHP und Vue die Funktion zum Austausch von Mitgliedspunkten und Geschenken implementieren, und stellen spezifische Codebeispiele bereit.
Zuerst müssen wir die Datenbank entwerfen, um Mitgliedspunkte und Geschenkinformationen zu speichern. Wir erstellen zwei Tabellen: Mitglieder
und Geschenke
. In der Tabelle members
werden Mitgliedsinformationen gespeichert, einschließlich Mitglieds-ID, Name und Punktefeldern. In der Tabelle Geschenke
werden Geschenkinformationen gespeichert, einschließlich der Geschenk-ID, des Namens und der erforderlichen Punktefelder. members
和gifts
。members
表存储会员信息,包括会员ID、姓名和积分字段。gifts
表存储礼品信息,包括礼品ID、名称和所需积分字段。
以下是members
表和gifts
members
und die Tabelle gifts
aufgeführt: CREATE TABLE members ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(50), points INT ); CREATE TABLE gifts ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(50), points_required INT );
<?php header('Content-Type: application/json'); $memberId = $_GET['memberId']; try { $pdo = new PDO('mysql:host=localhost;dbname=test', 'username', 'password'); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $stmt = $pdo->prepare('SELECT points FROM members WHERE id = :id'); $stmt->bindParam(':id', $memberId, PDO::PARAM_INT); $stmt->execute(); $result = $stmt->fetch(PDO::FETCH_ASSOC); echo json_encode($result); } catch(PDOException $e) { echo json_encode(['error' => $e->getMessage()]); } ?>
<?php header('Content-Type: application/json'); $memberId = $_POST['memberId']; $giftId = $_POST['giftId']; try { $pdo = new PDO('mysql:host=localhost;dbname=test', 'username', 'password'); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // 获取会员积分 $stmt = $pdo->prepare('SELECT points FROM members WHERE id = :id'); $stmt->bindParam(':id', $memberId, PDO::PARAM_INT); $stmt->execute(); $memberPoints = $stmt->fetchColumn(); // 获取礼品所需积分 $stmt = $pdo->prepare('SELECT points_required FROM gifts WHERE id = :id'); $stmt->bindParam(':id', $giftId, PDO::PARAM_INT); $stmt->execute(); $giftPoints = $stmt->fetchColumn(); if ($memberPoints >= $giftPoints) { // 减去积分 $stmt = $pdo->prepare('UPDATE members SET points = points - :points WHERE id = :id'); $stmt->bindParam(':id', $memberId, PDO::PARAM_INT); $stmt->bindParam(':points', $giftPoints, PDO::PARAM_INT); $stmt->execute(); // 插入兑换记录 $stmt = $pdo->prepare('INSERT INTO exchanges (member_id, gift_id) VALUES (:memberId, :giftId)'); $stmt->bindParam(':memberId', $memberId, PDO::PARAM_INT); $stmt->bindParam(':giftId', $giftId, PDO::PARAM_INT); $stmt->execute(); echo json_encode(['success' => true]); } else { echo json_encode(['success' => false, 'message' => 'Insufficient points']); } } catch(PDOException $e) { echo json_encode(['error' => $e->getMessage()]); } ?>
<template> <div> <h2>Member Points: {{ points }}</h2> <button @click="exchangeGift">Exchange Gift</button> </div> </template> <script> export default { data() { return { points: 0, memberId: 1, giftId: 1 }; }, mounted() { this.fetchPoints(); }, methods: { fetchPoints() { axios .get('api/getPoints.php', { params: { memberId: this.memberId } }) .then(response => { this.points = response.data.points; }) .catch(error => { console.error(error); }); }, exchangeGift() { axios .post('api/exchangeGift.php', { memberId: this.memberId, giftId: this.giftId }) .then(response => { if (response.data.success) { alert('Exchange successful'); this.fetchPoints(); } else { alert(response.data.message); } }) .catch(error => { console.error(error); }); } } }; </script>
<template> <div> <h2>Select Gift</h2> <select v-model="giftId"> <option v-for="gift in gifts" :key="gift.id" :value="gift.id">{{ gift.name }}</option> </select> </div> </template> <script> export default { data() { return { gifts: [], giftId: 1 }; }, mounted() { this.fetchGifts(); }, methods: { fetchGifts() { axios .get('api/getGifts.php') .then(response => { this.gifts = response.data; }) .catch(error => { console.error(error); }); } } }; </script>
<template> <div> <member-points></member-points> <gift-selection></gift-selection> </div> </template> <script> import MemberPoints from './MemberPoints.vue'; import GiftSelection from './GiftSelection.vue'; export default { components: { MemberPoints, GiftSelection } }; </script>
Das obige ist der detaillierte Inhalt vonPHP und Vue: So implementieren Sie die Funktion zum Austausch von Mitgliedspunkten und Geschenken. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!