ホームページ >バックエンド開発 >PHPチュートリアル >高度な PHP プログラミング: 複数の記事に対する Like 関数の設計と実装
PHP 開発者として、私たちは Web サイトやアプリケーションに同様の関数を追加する必要性によく遭遇します。この記事では、高度な PHP プログラミングを通じて複数記事のような関数を設計および実装する方法を紹介し、具体的なコード例を示します。
複数記事にいいねする機能を設計する前に、まず機能要件を明確にする必要があります。ウェブサイトに複数の記事を投稿し、各記事に「いいね!」を付けます。
CREATE TABLE likes ( id INT AUTO_INCREMENT PRIMARY KEY, article_id INT, user_id INT, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
<!DOCTYPE html> <html> <head> <title>多篇文章点赞功能</title> </head> <body> <div> <h1>文章标题1</h1> <p>文章内容1</p> <button class="like-btn" data-article-id="1">点赞</button> </div> <div> <h1>文章标题2</h1> <p>文章内容2</p> <button class="like-btn" data-article-id="2">点赞</button> </div> </body> </html>4. PHP バックエンドの実装PHP バックエンドでは、AJAX リクエストを受信して処理するコードを記述します。 like関数のロジック。以下は簡単な PHP コードの例です:
<?php require('db.php'); // 连接数据库 if ($_POST['action'] == 'like') { $article_id = $_POST['article_id']; $user_id = 1; // 假设用户id为1 $sql = "SELECT * FROM likes WHERE article_id = $article_id AND user_id = $user_id"; $result = mysqli_query($conn, $sql); if (mysqli_num_rows($result) == 0) { $sql = "INSERT INTO likes (article_id, user_id) VALUES ($article_id, $user_id)"; mysqli_query($conn, $sql); echo "点赞成功"; } else { echo "您已经点赞过了"; } } ?>
document.querySelectorAll('.like-btn').forEach((btn) => { btn.addEventListener('click', function() { const articleId = this.getAttribute('data-article-id'); fetch('like.php', { method: 'POST', body: JSON.stringify({action: 'like', article_id: articleId}) }) .then(response => response.text()) .then(data => { alert(data); }) .catch(error => console.error('Error:', error)); }); });
以上が高度な PHP プログラミング: 複数の記事に対する Like 関数の設計と実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。