element UI 在Table中插入图片,vue模糊查询

基于localstorage的图书管理,使用element UI,实现基本的增删改查功能

首页Home

  在首页实现模糊查询功能

  1 <template>
  2     <div class="home">
  3         <el-row>
  4             <el-button type="primary" @click="Add">新增</el-button>
  5         </el-row>
  6         <!-- <el-input v-model="input" ref="search" placeholder="请输入内容"></el-input> -->
  7         <el-input
  8             v-model="search"
  9             style="display: inline-block;width: 1300px"
 10             placeholder="请输入搜索内容"
 11         >
 12         </el-input>
 13         <el-table ref="tableData" :data="tables" style="width: 100%" stripe hover>
 14             <el-table-column type="index" label="序号" width="50"></el-table-column>
 15             <el-table-column prop="name" label="名称" width="180"></el-table-column>
 16             <el-table-column prop="img" label="主图" width="180">
 17                 <template slot-scope="scope">
 18                     <img
 19                         style="width:80px; max-heigth: 80px; display: block;margin: 0 auto;"
 20                         :src="scope.row.img"
 21                     />
 22                 </template>
 23             </el-table-column>
 24 
 25             <el-table-column prop="quantity" label="库存" width="180"></el-table-column>
 26             <el-table-column prop="price" label="价格" width="180"></el-table-column>
 27             <el-table-column label="操作" width="150">
 28                 <template slot-scope="scope">
 29                     <el-button size="mini" @click="handleEdit(scope.$index)">编辑</el-button>
 30                     <el-button size="mini" type="danger" @click="handleDelete(scope.$index)"
 31                         >删除</el-button
 32                     >
 33                 </template>
 34             </el-table-column>
 35         </el-table>
 36     </div>
 37 </template>
 38 
 39 <script>
 40 export default {
 41     name: "Home",
 42     components: {
 43         // HelloWorld
 44     },
 45     data() {
 46         return {
 47             search: "",
 48             tableData: [
 49                 {
 50                     name: "",
 51                     img: "",
 52                     quantity: "",
 53                     price: "",
 54                 },
 55             ],
 56         }
 57     },
 58     methods: {
 59         Add() {
 60             this.$router.push({
 61                 name: "New",
 62             })
 63         },
 64         handleEdit(index) {
 65             this.$router.push({
 66                 name: "Edit",
 67                 query: { index },
 68             })
 69         },
 70         handleDelete(index) {
 71             this.$confirm("此操作将永久删除该数据, 是否继续?", "提示", {
 72                 confirmButtonText: "确定",
 73                 cancelButtonText: "取消",
 74                 type: "warning",
 75             })
 76                 .then(() => {
 77                     let data = JSON.parse(localStorage.getItem("data"))
 78                     data.splice(index, 1)
 79                     localStorage.setItem("data", JSON.stringify(data))
 80                     this.loadData()
 81                     this.$message({
 82                         type: "success",
 83                         message: "删除成功!",
 84                     })
 85                 })
 86                 .catch(() => {
 87                     this.$message({
 88                         type: "info",
 89                         message: "已取消删除",
 90                     })
 91                 })
 92         },
 93         loadData() {
 94             let data = JSON.parse(localStorage.getItem("data"))
 95             // this.list = data
 96             this.tableData = data
 97         },
 98     },
 99     created() {
100         this.loadData()
101     },
102     computed: {
103         tables() {
104             const search = this.search
105             if (search) {
106                 return this.tableData.filter((data) => {
107                     return Object.keys(data).some((key) => {
108                         return (
109                             String(data[key])
110                                 .toLowerCase()
111                                 .indexOf(search) > -1
112                         )
113                     })
114                 })
115             }
116             return this.tableData
117         },
118     },
119 }
120 </script>

 

新增页New

 1 <template>
 2     <div class="edit">
 3         <el-form
 4             :model="numberValidateForm"
 5             ref="numberValidateForm"
 6             label-width="100px"
 7             class="demo-ruleForm"
 8         >
 9             <el-form-item
10                 prop="name"
11                 label="名称"
12                 :rules="[{ required: true, message: '名称不能为空' }]"
13             >
14                 <el-input
15                     type="name"
16                     v-model.number="numberValidateForm.name"
17                     autocomplete="off"
18                 ></el-input>
19             </el-form-item>
20             <el-form-item label="主图" prop="img" :rules="[{ required: false }]">
21                 <el-input
22                     type="img"
23                     v-model.number="numberValidateForm.img"
24                     autocomplete="off"
25                 ></el-input>
26             </el-form-item>
27             <el-form-item label="库存" prop="quantity" :rules="[{ required: false }]">
28                 <el-input
29                     type="quantity"
30                     v-model.number="numberValidateForm.quantity"
31                     autocomplete="off"
32                 ></el-input>
33             </el-form-item>
34             <el-form-item label="价格" prop="price" :rules="[{ required: false }]">
35                 <el-input
36                     type="price"
37                     v-model.number="numberValidateForm.price"
38                     autocomplete="off"
39                 ></el-input>
40             </el-form-item>
41             <el-form-item>
42                 <el-button type="primary" @click="submitForm('numberValidateForm')"
43                     >提交</el-button
44                 >
45                 <el-button @click="resetForm('numberValidateForm')">重置</el-button>
46             </el-form-item>
47         </el-form>
48     </div>
49 </template>
50 
51 <script>
52 export default {
53     data() {
54         return {
55             list: [],
56             numberValidateForm: {
57                 name: "",
58                 img: "",
59                 quantity: "",
60                 price: "",
61             },
62         }
63     },
64     methods: {
65         submitForm() {
66             if (this.numberValidateForm.name == "") {
67                 this.$alert("名称不能为空", {
68                     confirmButtonText: "确定",
69                 })
70                 return
71             }
72             let data = JSON.parse(localStorage.getItem("data"))
73             if (data) {
74                 data.push(this.numberValidateForm)
75                 localStorage.setItem("data", JSON.stringify(data))
76             } else {
77                 this.list.push(this.numberValidateForm)
78                 localStorage.setItem("data", JSON.stringify(this.list))
79             }
80             this.$router.push({
81                 name: "Home",
82             })
83         },
84         resetForm() {
85             this.numberValidateForm = []
86         },
87     },
88 }
89 </script>
90 
91 <style></style>

 

修改页Edit

 1 <template>
 2     <div class="edit">
 3         <el-form
 4             :model="numberValidateForm"
 5             ref="numberValidateForm"
 6             label-width="100px"
 7             class="demo-ruleForm"
 8         >
 9             <el-form-item
10                 prop="name"
11                 label="名称"
12                 :rules="[{ required: true, message: '名称不能为空' }]"
13             >
14                 <el-input
15                     type="name"
16                     v-model.number="numberValidateForm.name"
17                     autocomplete="off"
18                 ></el-input>
19             </el-form-item>
20             <el-form-item label="主图" prop="img" :rules="[{ required: false }]">
21                 <el-input
22                     type="img"
23                     v-model.number="numberValidateForm.img"
24                     autocomplete="off"
25                 ></el-input>
26             </el-form-item>
27             <el-form-item label="库存" prop="quantity" :rules="[{ required: false }]">
28                 <el-input
29                     type="quantity"
30                     v-model.number="numberValidateForm.quantity"
31                     autocomplete="off"
32                 ></el-input>
33             </el-form-item>
34             <el-form-item label="价格" prop="price" :rules="[{ required: false }]">
35                 <el-input
36                     type="price"
37                     v-model.number="numberValidateForm.price"
38                     autocomplete="off"
39                 ></el-input>
40             </el-form-item>
41             <el-form-item>
42                 <el-button type="primary" @click="submitForm('numberValidateForm')"
43                     >提交</el-button
44                 >
45                 <el-button @click="resetForm('numberValidateForm')">重置</el-button>
46             </el-form-item>
47         </el-form>
48     </div>
49 </template>
50 
51 <script>
52 export default {
53     data() {
54         return {
55             numberValidateForm: {
56                 name: "",
57                 img: "",
58                 quantity: "",
59                 price: "",
60             },
61         }
62     },
63     methods: {
64         loadData() {
65             let id = this.$route.query.index
66             let data = JSON.parse(localStorage.getItem("data"))
67             this.numberValidateForm = data[id]
68         },
69         submitForm() {
70             if (this.numberValidateForm.name == "") {
71                 this.$alert("名称不能为空", {
72                     confirmButtonText: "确定",
73                 })
74                 return
75             }
76             let id = this.$route.query.index
77             let data = JSON.parse(localStorage.getItem("data"))
78             data.splice(id, 1, this.numberValidateForm)
79             localStorage.setItem("data", JSON.stringify(data))
80             this.$router.push({
81                 name: "Home",
82             })
83         },
84         resetForm() {
85             this.numberValidateForm = []
86         },
87     },
88     created() {
89         this.loadData()
90     },
91 }
92 </script>
93 
94 <style></style>

 

效果图:

 项目GitHub地址:      https://github.com/strongerPian/Book-Set.git

posted @ 2020-07-25 09:13  strongerPian  阅读(1020)  评论(0编辑  收藏  举报
返回顶端