AJAX——图书管理案例

以下是一个简化的AJAX实现图书管理的例子。假设我们有一个简单的图书列表和一个表单用于添加新图书,我们将使用jQuery来处理AJAX请求。

HTML部分:




<div id="book-list">
  <!-- 图书列表将被动态加载和显示在这里 -->
</div>
 
<form id="add-book-form">
  <input type="text" name="title" placeholder="图书名称">
  <input type="text" name="author" placeholder="作者名称">
  <button type="submit">添加图书</button>
</form>

JavaScript部分(使用jQuery):




$(document).ready(function() {
  // 加载图书列表
  loadBooks();
 
  // 表单提交事件
  $('#add-book-form').submit(function(e) {
    e.preventDefault(); // 阻止表单默认提交行为
    var title = $(this).find('input[name="title"]').val();
    var author = $(this).find('input[name="author"]').val();
    addBook(title, author); // 添加图书
    $(this).find('input[type="text"]').val(''); // 清空输入字段
  });
  
  // 定义加载图书的函数
  function loadBooks() {
    $.ajax({
      url: 'get_books.php', // 服务器端的URL
      type: 'GET',
      dataType: 'json',
      success: function(books) {
        var list = $('#book-list');
        list.empty(); // 清空列表
        $.each(books, function(index, book) {
          list.append('<div>' + book.title + ' by ' + book.author + '</div>');
        });
      },
      error: function() {
        alert('Error loading books');
      }
    });
  }
 
  // 定义添加图书的函数
  function addBook(title, author) {
    $.ajax({
      url: 'add_book.php',
      type: 'POST',
      data: { title: title, author: author },
      dataType: 'json',
      success: function(response) {
        if (response.status === 'success') {
          loadBooks(); // 加载图书列表以更新视图
        } else {
          alert('Error adding book');
        }
      },
      error: function() {
        alert('Error adding book');
      }
    });
  }
});

在这个例子中,我们使用jQuery的$.ajax()方法来处理AJAX请求。loadBooks()函数获取所有图书,并将它们添加到页面上的列表中。addBook()函数通过POST请求添加一本新图书,并在成功后重新加载图书列表。这里假设有get_books.phpadd_book.php两个服务器端脚本用于处理请求。

最后修改于:2024年08月15日 12:37

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日