热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:vue.js快速搭建图书管理平台

篇首语:本文由编程笔记#小编为大家整理,主要介绍了vue.js快速搭建图书管理平台相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了vue.js快速搭建图书管理平台相关的知识,希望对你有一定的参考价值。




上一期简单讲解了vue的基本语法,这一次我们做一个小项目,搭建一个简单的图书管理平台,能够让我们更深刻的理解这门语言的妙用。


  前  言

上一期简单讲解了vue的基本语法,这一次我们做一个小项目,搭建一个简单的图书管理平台,能够让我们更深刻的理解这门语言的妙用。











































  1、DEMO样式

 

  首先我们需要搭建一个简单的demo样式,推荐大家使用bootstrap,可以很快的搭建出一个清晰简洁的页面。

  给大家分享一段我的代码吧。

  


<div class="container">
<div class="col-md-6 col-md-offset-3">
<h1>Vue demoh1>

<div id="app">
<table class="table table-hover ">
<caption>caption>
<thead>
<tr>
<th>序号th>
<th>书名th>
<th>作者th>
<th>价格th>
<th>操作th>
tr>
thead>
table>

<div id="add-book">
<legend>添加书籍legend>
<div class="form-group">
<label for="group">书名label>
<input type="text" class="form-control" id="group">
div>
<div class="form-group">
<label for="author">作者label>
<input type="text" class="form-control" id="author">
div>
<div class="form-group">
<label for="price">价格label>
<input type="text" class="form-control" id="price">
div>
<button class="btn btn-primary btn-block">添加button>
<button class="btn btn-primary btn-block">查询button>
div>
<div id="update-book">
<legend>修改书籍legend>
<div class="form-group">
<label for="group1">书名label>
<input type="text" class="form-control" id="group1">
div>
<div class="form-group">
<label for="author1">作者label>
<input type="text" class="form-control" id="author1">
div>
<div class="form-group">
<label for="price1">价格label>
<input type="text" class="form-control" id="price1">
div>
<button class="btn btn-primary btn-block">完成button>
div>
div>
div>
div>

  运用了bootstrap的栅格系统,和一些简单的组件,不光简单快捷,还能自动实现响应式呢。

  而且做出来的效果也不难看,挺整洁的。

  给大家看下刚开始的效果图。

  如果对这个CSS框架没有了解的话,自己写一下样式也没关系。

 








  2、创建vue实例

   

  接下来,我们导入自己的JS文件,创建一个vue实例。

  


new Vue({
el:
\'#app\',
data: {
book: {
id:
0,
author:
\'\',
name:
\'\',
price:
\'\'
},
books: [{
id:
1,
author:
\'曹雪芹\',
name:
\'红楼梦\',
price:
32.0
}, {
id:
2,
author:
\'施耐庵\',
name:
\'水浒传\',
price:
30.0
}, {
id:
\'3\',
author:
\'罗贯中\',
name:
\'三国演义\',
price:
24.0
}, {
id:
4,
author:
\'吴承恩\',
name:
\'西游记\',
price:
20.0
}]
}
});

 

  data中是一些初始的数据,可以随意填写。

 








3 、将各种指令添加到html

  

  我们说过,vue的核心聚焦在视图层,所以指令是最重要的一步,我们一点一点说。

  不过因为指令分布的比较乱,所以直接附上全部代码,然后我一个一个的解释。

  


<div id="app">
<table class="table table-hover ">
<caption>caption>
<thead>
<tr>
<th>序号th>
<th>书名th>
<th>作者th>
<th>价格th>
<th>操作th>
tr>
thead>
<tbody>
<tr v-cloak v-for="book in books">
<td>{{book.id}}td>
<td>{{book.name}}td>
<td>{{book.author}}td>
<td>{{book.price}}td>
<template v-if="book.id%2==0">
<td class="text-left">
<button type="button" class="btn btn-success" @click="delBook(book)" class="del">删除button>
<button type="button" class="btn btn-success" @click="updateBook(book)">修改button>
td>
template>
<template v-else>
<td class="text-left">
<button type="button" class="btn btn-danger" @click="delBook(book)" class="del">删除button>
<button type="button" class="btn btn-danger" @click="updateBook(book)">修改button>
td>
template>
tr>
tbody>
table>

<div id="add-book">
<legend>添加书籍legend>
<div class="form-group">
<label for="group">书名label>
<input type="text" class="form-control" id="group" v-model="book.name">
div>
<div class="form-group">
<label for="author">作者label>
<input type="text" class="form-control" id="author" v-model="book.author">
div>
<div class="form-group">
<label for="price">价格label>
<input type="text" class="form-control" id="price" v-model="book.price">
div>
<button class="btn btn-primary btn-block" v-on:click="addBook()">添加button>
<button class="btn btn-primary btn-block" v-on:click="searchBook()">查询button>
div>
<div id="update-book">
<legend>修改书籍legend>
<div class="form-group">
<label for="group1">书名label>
<input type="text" class="form-control" id="group1" v-model="book.name">
div>
<div class="form-group">
<label for="author1">作者label>
<input type="text" class="form-control" id="author1" v-model="book.author">
div>
<div class="form-group">
<label for="price1">价格label>
<input type="text" class="form-control" id="price1" v-model="book.price">
div>
<button class="btn btn-primary btn-block" v-on:click="updatesBook()">完成button>
div>
div>

  

  首先,将id为app的vue实例挂载到DOM节点上,如果对于这些基本内容还不了解的话,可以去看我的上一篇博客,详细的介绍了关于vue的基础知识。

  下面的表格,在tr中通过一个v-for循环,将vue实例data中的数据,全部载入到表格里。

  细心的读者应该发现了,我在v-for前写了一个v-cloak,这是干什么的呢?

  用过angular,vue这种框架的人应该都知道,当我们用{{}}绑定数据的时候,当页面刷新的瞬间,会看到闪烁而过的原始代码。

  当信息量比较大的时候,这种体验无疑是十分恶劣的,这个时候,v-cloak这个指令保持在元素上直到关联实例结束编译。

  和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的 Mustache 标签直到实例准备完毕。

  这样就解决了刷新的瞬间页面出现大量乱码的情况。

  下面的v-if和v-else就是为了练习一下各种指令啦,让我们的按钮生成的时候可以轮流生成两种颜色~

  而v-model是为了在input中输入内容时,可以动态的取到输入的内容。

  还是那句话,这些基本指令不认识的话,可以去我的上一篇博客查看。

  那些v-on:click绑定的函数,一会一个一个详细解释,现在先来看一下效果。

  

  还不错吧~接下来我们就开始说一下各个函数。

  


addBook: function() {
//计算书的id
this.book.id = this.books.length + 1;
this.books.push(this.book);
//将input中的数据重置
this.book = {};
}

  这个是添加函数,大家可以去上面看一下vue实例中data里面的代码。

  其实就只是这么几行代码,vue的强大就已经展现的淋漓尽致了。

  因为我们在输入框中绑定了v-model,所以我们输入的内容就会动态的与book这个对象同步。

  这个函数的原理就是给book那个对象的id赋值,然后将通过v-model动态绑定到输入框上的数据,也就是我们输入的数据,push进books那个数组。

  最后将book对象清空,也就是把我们的输入框清空了。

  区区3行代码,信息的录入就完成了,是不是很神奇呢。

  哦对了,在vue实例中,this指向的就是本身这个vue实例,对面向对象的概念没有了解的话,建议百度一下this指向问题。

  下面看一下删除  


delBook: function(book) {
var blength = this.books.length;
this.books.splice(book.id-1, 1);
for( var i = 0; i ) {
if(book.id <this.books[i].id) {
this.books[i].id -= 1;
}
}
}

  删除的原理是取到当前books数组的长度,当前选中的那一条的下标是它的id-1,用splice方法将它删除。

  然后通过循环,将id比被删除数据大的那些项的id都减去1,保持序号的连续。

  然后是修改

  


updateBook: function(book) {
$(
"#add-book").css("display","none");
$(
"#update-book").css("display","block");
id
= book.id;
},
updatesBook:
function(book) {
this.book.id = id;
this.books.splice(id-1,1,this.book);
$(
"#add-book").css("display","block");
$(
"#update-book").css("display","none");
this.book = {};

  第一个函数就是将修改框弹出来,把添加的框隐藏掉,然后把需要修改的id绑定到一个全局的变量上~

  然后第一个函数才是真正的修改命令。

  将刚才绑定的全局变量,赋值给当前id,然后还是用splice方法,用输入的内容把原来的内容替换掉~

  然后还是同样的,将book对象也就是输入框清空。

 

 


  结尾

 这样一个简单的信息录入平台就完成了,虽然代码不多,但是足以让我们深深感受到vue的强大。

 未来页面的发展趋势,一定是绕不开这样的设计思路的。

 下一期为大家带来一个拼图游戏,感兴趣的可以深入了解一下vue的系统。




推荐阅读
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • 【shell】网络处理:判断IP是否在网段、两个ip是否同网段、IP地址范围、网段包含关系
    本文介绍了使用shell脚本判断IP是否在同一网段、判断IP地址是否在某个范围内、计算IP地址范围、判断网段之间的包含关系的方法和原理。通过对IP和掩码进行与计算,可以判断两个IP是否在同一网段。同时,还提供了一段用于验证IP地址的正则表达式和判断特殊IP地址的方法。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • 在JavaScript中,函数没有重载的概念,如果声明了多个重名的函数,不管函数的形参个数是否一样,只有最后一个有效。如果调用函数时传入的参数个数与函数定义时的参数个数不符,会出现不同的情况。函数调用时,传入的参数个数少于函数定义时的参数个数,未传入的参数会被当做undefined处理,可能会导致错误。而传入的参数个数多于函数定义时的参数个数,多余的参数不会被使用,但不会报错。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文介绍了在使用vue和webpack进行异步组件按需加载时可能出现的报错问题,并提供了解决方法。同时还解答了关于局部注册组件和v-if指令的相关问题。 ... [详细]
  • 深入理解CSS中的margin属性及其应用场景
    本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • HTML5网页模板怎么加百度统计?
    本文介绍了如何在HTML5网页模板中加入百度统计,并对模板文件、css样式表、js插件库等内容进行了说明。同时还解答了关于HTML5网页模板的使用方法、表单提交、域名和空间的问题,并介绍了如何使用Visual Studio 2010创建HTML5模板。此外,还提到了使用Jquery编写美好的HTML5前端框架模板的方法,以及制作企业HTML5网站模板和支持HTML5的CMS。 ... [详细]
  • React基础篇一 - JSX语法扩展与使用
    本文介绍了React基础篇一中的JSX语法扩展与使用。JSX是一种JavaScript的语法扩展,用于描述React中的用户界面。文章详细介绍了在JSX中使用表达式的方法,并给出了一个示例代码。最后,提到了JSX在编译后会被转化为普通的JavaScript对象。 ... [详细]
  • 本文介绍了2015年九月八日的js学习总结及相关知识点,包括参考书《javaScript Dom编程的艺术》、js简史、Dom、DHTML、解释型程序设计和编译型程序设计等内容。同时还提到了最佳实践是将标签放到HTML文档的最后,并且对语句和注释的使用进行了说明。 ... [详细]
  • jQuery如何判断一个元素是否被点击?
    本文介绍了使用jQuery判断一个元素是否被点击的方法,并通过示例进行了具体说明。注意要指定父级,否则会执行多次。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
author-avatar
戊辰冬月半
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有