当前位置: 首页 > article >正文

AJAX综合案例——图书管理

黑马程序员视频地址:

AJAX-Day02-10.案例_图书管理AJAX-Day02-10.案例_图书管理_总结_V1.0是黑马程序员前端AJAX入门到实战全套教程,包含学前端框架必会的(ajax+node.js+webpack+git),一套全覆盖的第25集视频,该合集共计140集,视频收藏或关注UP主,及时了解更多相关视频内容。https://www.bilibili.com/video/BV1MN411y7pw?vd_source=0a2d366696f87e241adc64419bf12cab&spm_id_from=333.788.player.switch&p=25https://www.bilibili.com/video/BV1MN411y7pw?vd_source=0a2d366696f87e241adc64419bf12cab&spm_id_from=333.788.player.switch&p=25

步骤一:Bootstrap弹框

1. 引入bootstrap.css 和 bootstrap.js

 <!-- 引入bootstrap.css --> 
 <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.2/dist/css/bootstrap.min.css" rel="stylesheet">


<!-- 引入bootstrap.js -->
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.2/dist/js/bootstrap.min.js"></script>

 2. 准备弹框标签,确认结构

<div class="modal" tabindex="-1">
  <div class="modal-dialog">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">Modal title</h5>
        <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
      </div>
      <div class="modal-body">
        <p>Modal body text goes here.</p>
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button>
        <button type="button" class="btn btn-primary">Save changes</button>
      </div>
    </div>
  </div>
</div>

 3. 通过自定义属性,控制弹框的显示和隐藏

1)弹框显示 

<!--第一步:触发弹框,按钮绑定自定义属性:data-bs-toggle="modal"和data-bs-target="CSS选择器"-->
<button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target=".myalert">
    显示弹框
  </button>


 <!-- 第二步:给弹框加上myalert类,以便区分同一页面不同弹窗 -->
  <div class="modal myalert" tabindex="-1">
      <!--省略代码好几行-->
  </div>

2)弹框隐藏

<!--给需要有隐藏效果的按钮加上自定义属性data-bs-dismiss="modal"-->
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button>

4.通过JS控制,控制弹框显示或隐藏

1)弹窗显示

//第一步:给弹窗模块实例化,从而获取show方法与hide方法
const modalDom = document.querySelector(".name-box")
const modal = new bootstrap.Modal(modalDom)
//编辑按钮绑定事件
document.querySelector(".edit-btn").addEventListener("click", () => {
  //第二步:调用显示弹窗函数
  modal.show()
})

实例化(new)的作用:继承bootstraop.Modal原型对象里的方法,见下图观察bootstrap对象

console.dir(bootstrap)

2)弹窗隐藏

//保存按钮绑定事件
    document.querySelector(".save-btn").addEventListener("click", () => {
      //隐藏弹框
      modal.hide()
    })

步骤二:渲染列表(查)

const creator = "USER_A001" //给服务器一个标识,用来获取某个用户的专属数据 
function getData()
{
  axios({
    url: "https://hmajax.itheima.net/api/books",
    params: {
      creator
    }
  }).then(result => {
    const bookList = result.data.data    //将服务器返回的数据用一个数组来接收
    const htmlStr = bookList.map((item, index) => {  //map数组映射
      return `
      <tr>          
      <td>${index + 1}</td>          
      <td>${item.bookname}</td>          
      <td>${item.author}</td>          
      <td>${item.publisher}</td>          
      <td>            
      <span class="del">删除</span>            
      <span class="edit">编辑</span>          
      </td>        
      </tr>
      `
    }).join("")  //join将数组用双引号内的东西拼接成字符串
    document.querySelector(".list").innerHTML = htmlStr   //将内容渲染到页面上
    

  }).catch(error => {
    console.log(error)
  })
}

getData()    //调用函数

步骤三:新增图书(增)

//创建弹窗对象
const addModalDom = document.querySelector(".add-modal")
const addModal = new bootstrap.Modal(addModalDom)
//保存按钮绑定事件
document.querySelector(".add-btn").addEventListener("click", () => {
  //获取表单数据
  const addDataDom = document.querySelector(".add-form") 
  const addData = serialize(addDataDom, {hash: true, empty: true})
  //向服务器提交数据
  axios({
    url: "https://hmajax.itheima.net/api/books",
    method: "POST",
    data: {
      ...addData,
      creator
    }
  }).then(result => {
    alert("数据提交成功")
    //清除表单数据
    addDataDom.reset()
    //渲染数据
    getData()
    //隐藏弹窗
    addModal.hide()
  }).catch(error => {
    alert("数据提交失败,请重试")
  })
  
})

步骤四:删除图书(删)

document.querySelector(".list").addEventListener("click", e => { //事件委托
  if(e.target.classList.contains("del"))  //判断触发源
  {
    const theId = e.target.parentNode.dataset.id
    axios({
      url: `https://hmajax.itheima.net/api/books/${theId}`,  //以路径方式提交数据
      method: "DELETE"   //告诉服务器此次事件的方法
    }).then(result => {
      alert("成功删除!")
      getData()    //刷新数据
    }).catch(error => {
      alert("删除失败!")
    })
  }
})

步骤五:编辑图书(改)

//创建编辑弹窗实例对象
const editModalDom = document.querySelector(".edit-modal")
const editModal = new bootstrap.Modal(editModalDom)
//编辑按钮绑定事件 事件委托
document.querySelector(".list").addEventListener("click", e => {
  if(e.target.classList.contains("edit"))
  {
    //获取数据
    const theId = e.target.parentNode.dataset.id
    axios({
      url: `https://hmajax.itheima.net/api/books/${theId}`
    }).then(result => {
      //显示数据
      const editData = result.data.data
      const key = Object.keys(editData)    //获取对象的所有属性名
      
      key.forEach(item => {    //遍历数组,每遍历一次,将获取的数据赋值给拥有对应属性名的元素值
        document.querySelector(`.edit-modal .${item}`).value = editData[item]
        
      })
    }).catch(error => {
      alert("获取数据失败!")
    })
    //显示弹框
    editModal.show()
  }
})

//修改按钮绑定事件
document.querySelector(".edit-btn").addEventListener("click", () => {
  //获取数据
  const editDataDom = document.querySelector(".edit-form")
  const {id, bookname, author, publisher} = serialize(editDataDom, {hash: true, empty: true})    //解构
  //提交数据
  axios({
    url: `https://hmajax.itheima.net/api/books/${id}`,
    method: "PUT",    //看接口文档要求提交的方式,跟接口文档保持一致
    data: {    //为什么用data而不用params?接口文档要求的!
      bookname,
      author,
      publisher,
      creator
    }
  }).then(result => {
    alert("修改成功!")
    //关闭弹窗
    editModal.hide()
    //刷新数据
    getData()
  }).catch(error => {
    alert("提交失败!")
  })
  
})

http://www.kler.cn/a/526101.html

相关文章:

  • 房屋租赁系统在数字化时代中如何重塑租赁服务与提升市场竞争力
  • YOLO11/ultralytics:环境搭建
  • Go反射指南
  • 多协议网关BL110钡铼6路RS485转MQTT协议云网关
  • 【HarmonyOS之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(一)
  • Shodan Dorks安装指南,通过Shodan搜索漏洞
  • 01-时间与管理
  • DeepSeek-R1 论文解读:强化学习如何 “炼” 出超强推理模型?
  • 使用 Context API 管理临时状态,避免 Redux/Zustand 的持久化陷阱
  • Web-3.0学习路线
  • Python学习之旅:进阶阶段(六)数据结构-有序字典(collections.OrderedDict)
  • 单片机串口打印printf函数显示内容(固件库开发)
  • 蓝桥云客 好数
  • 【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.24 随机宇宙:生成现实世界数据的艺术
  • DeepSeek r1本地安装全指南
  • Java中运行Python程序
  • vscode+WSL2(ubuntu22.04)+pytorch+conda+cuda+cudnn安装系列
  • Rust语言进阶之chain用法实例(九十七)
  • 爱快 IK-W35 面板式AP 简单开箱评测和拆解,双频WiFi6 AX3000,2.5G网口
  • 2025年1月22日(网络编程)
  • 数据结构实战之线性表(三)
  • 多目标优化策略之一:非支配排序
  • 前端axios拦截器
  • 短链接项目02---依赖的添加和postman测试
  • .Net / C# 繁体中文 与 简体中文 互相转换, 支持地方特色词汇
  • 【Unity3D】实现横版2D游戏——攀爬绳索(简易版)