失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 案例:图书管理(包括图书列表展示 添加 修改 删除图书功能)

案例:图书管理(包括图书列表展示 添加 修改 删除图书功能)

时间:2024-02-01 10:18:45

相关推荐

案例:图书管理(包括图书列表展示 添加 修改 删除图书功能)

案例:图书管理

功能如下:

(1)图书列表

实现静态列表效果基于数据实现模板效果处理每行的操作按钮

(2)添加图书

实现表单的静态效果添加图书表单域数据绑定添加按钮事件绑定实现添加业务逻辑

(3)修改图书

修改信息填充到表单修改后重新提交表单重用添加和修改的方法

(4) 删除图书

删除按钮绑定事件处理方法实现删除业务逻辑

(5)常用特性应用场景

过滤器(格式化日期)自定义指令(获取表单焦点)计算属性(统计图书数量)侦听器(验证图书存在性)生命周期(图书数据处理)

代码:

<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>案例:图书馆案例</title><style>.grid {margin: auto;width: 500px;text-align: center;}.grid table {width: 100%;border-collapse: collapse;}.grid th,td {padding: 10;border: 1px dashed orange;height: 35px;line-height: 35px;}.grid th {background-color: orange;}.grid .book {padding-bottom: 10px;padding-top: 5px;background-color: #F3DCAB;}.grid .total {height: 30px;line-height: 30px;background-color: #F3DCAB;border-top: 1px solid #C2D89A;}</style></head><body><div id="app"><div class="grid"><div><h1>图书管理</h1><div class="book"><div><label for="id">编号:</label><input type="text" id="id" v-model='id' :disabled='flag' v-focus><label for="name">名称:</label><input type="text" id="name" v-model='name'><button @click='handle' :disabled='submitFlag'>提交</button></div></div></div><div class="total"><span>图书总数:</span><span>{{total}}</span></div><table><thead><tr><th>编号</th><th>名称</th><th>时间</th><th>操作</th></tr></thead><tbody><tr :key='item.id' v-for='item in books'><td>{{item.id}}</td><td>{{item.name}}</td><td>{{item.date | format('yyyy-MM-dd hh:mm:ss')}}</td><td><a href="" @click.prevent='toEdit(item.id)'>修改</a><span>|</span><a href="" @click.prevent='deleteBook(item.id)'>删除</a></td></tr></tbody></table></div></div><script src="js/vue.js"></script><script>// 自定义指令:获取焦点Vue.directive('focus', {inserted: function (el) {el.focus();}});// 过滤器:格式化日期Vue.filter('format', function (value, arg) {function dateFormat(date, format) {if (typeof date === "string") {var mts = date.match(/(\/Date\((\d+)\)\/)/);if (mts && mts.length >= 3) {date = parseInt(mts[2]);}}date = new Date(date);if (!date || date.toUTCString() == "Invalid Date") {return "";}var map = {"M": date.getMonth() + 1, //月份 "d": date.getDate(), //日 "h": date.getHours(), //小时 "m": date.getMinutes(), //分 "s": date.getSeconds(), //秒 "q": Math.floor((date.getMonth() + 3) / 3), //季度 "S": date.getMilliseconds() //毫秒 };format = format.replace(/([yMdhmsqS])+/g, function (all, t) {var v = map[t];if (v !== undefined) {if (all.length > 1) {v = '0' + v;v = v.substr(v.length - 2);}return v;} else if (t === 'y') {return (date.getFullYear() + '').substr(4 - all.length);}return all;});return format;}return dateFormat(value, arg);});// 图书管理 - 图书列表展示功能// 注意事项:<a href="" @click.prevent> 修改</a >// 事件绑定时,可以只添加修饰符,而不绑定事件函数var vm = new Vue({el: '#app',data: {flag: false,submitFlag: false,id: '',name: '',books: []},methods: {handle: function () {if (this.flag) {// 编辑图书// 就是根据当前的ID去更新数组中对应的数据this.books.some((item) => {if (item.id == this.id) {item.name = this.name;// 完成更新操作之后,需要终止循环return true;}});this.flag = false;} else {// 添加图书var book = {};book.id = this.id;book.name = this.name;book.date = '';this.books.push(book);}// 清空表单this.id = '';this.name = '';},// 修改图书toEdit: function (id) {// 禁止修改IDthis.flag = true;console.log(id);// 根据ID查询出要编辑的数据var book = this.books.filter(function (item) {return item.id == id;});console.log(book);// 把获取到的信息填充到表单this.id = book[0].id;this.name = book[0].name;},deleteBook: function (id) {// 删除图书// 根据id从数组中查找元素的索引// var index = this.books.findIndex(function (item) {//return item.id = id;// });// 根据索引删除数组元素// this.books.splice(index, 1);// 方法二:通过filter方法进行删除this.books = this.books.filter(function (item) {return item.id != id;});}},// 计算属性computed: {total: function () {// 计算图书的总数return this.books.length;}},// 侦听器:验证图书存在性watch: {name: function (val) {// 验证图书名称是否已经存在var flag = this.books.some(function (item) {return item.name == val;});if (flag) {// 图书名称存在this.submitFlag = true;} else {// 图书名称不存在this.submitFlag = false;}}},mounted: function () {// 该生命周期钩子函数被触发的时候,模板已经可以使用// 一般此时用于获取后台数据,然后把数据填充到模板var data = [{id: 1,name: '三国演义',date: 2525609975000}, {id: 2,name: '水浒传',date: 2525609975000}, {id: 3,name: '红楼梦',date: 2525609975000}, {id: 4,name: '西游记',date: 2525609975000}];this.books = data;}});// some() 方法用于检测数组中的元素是否满条件(函数提供)。// some() 方法会依次执行数组的每个元素:// 如果有一个元素满足条件,则表达式返回true, 剩余不会再执行检测。// 如果没有满足条件的元素,则返回false。</script></body></html>

如果觉得《案例:图书管理(包括图书列表展示 添加 修改 删除图书功能)》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。