index.html 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. <!DOCTYPE html>
  2. <html lang="cn">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Vue Demo</title>
  6. <script src="js/axios.min.js"></script>
  7. <link rel="stylesheet" href="elementUI/index.css">
  8. <script src="js/vue.min.js"></script>
  9. <script src="elementUI/index.js"></script>
  10. <link rel="stylesheet" href="css/main.css">
  11. <script src="js/util.js"></script>
  12. </head>
  13. <body>
  14. <template>
  15. <div class="app-container" id="app">
  16. <el-form :inline="true" :model="param" class="demo-form-inline">
  17. <el-form-item label="名字">
  18. <el-input v-model="param.name" placeholder="名字"/>
  19. </el-form-item>
  20. <el-form-item label="日期">
  21. <el-input v-model="param.date"/>
  22. </el-form-item>
  23. <el-form-item>
  24. <el-button type="primary" @click="queryList">查询</el-button>
  25. </el-form-item>
  26. </el-form>
  27. <template>
  28. <!--添加-->
  29. <el-row>
  30. <el-button @click="createOne()">添加</el-button>
  31. </el-row>
  32. <!--数据-->
  33. <el-table
  34. :data="tableData"
  35. border
  36. style="width: 100%"
  37. >
  38. <el-table-column
  39. fixed
  40. prop="date"
  41. label="日期"
  42. width="150"
  43. />
  44. <el-table-column
  45. prop="name"
  46. label="姓名"
  47. width="150"
  48. />
  49. <el-table-column
  50. prop="email"
  51. label="email地址"
  52. width="300"
  53. />
  54. <el-table-column
  55. fixed="right"
  56. label="操作"
  57. width="100"
  58. >
  59. <template slot-scope="scope">
  60. <el-button
  61. type="text"
  62. size="small"
  63. @click="editOne(scope.row)"
  64. >编辑
  65. </el-button>
  66. <el-button
  67. size="small"
  68. type="text"
  69. @click="deleteAlert(scope.row.id)"
  70. >删除
  71. </el-button>
  72. </template>
  73. </el-table-column>
  74. </el-table>
  75. <!--编辑层-->
  76. <el-dialog title="编辑" :visible.sync="dialogFormVisible">
  77. <el-form :model="editNews">
  78. <el-form-item label="姓名" :label-width="formLabelWidth">
  79. <el-input v-model="editNews.name" autocomplete="off"/>
  80. </el-form-item>
  81. <el-form-item label="Email" :label-width="formLabelWidth">
  82. <el-input v-model="editNews.email" placeholder=""/>
  83. </el-form-item>
  84. </el-form>
  85. <div slot="footer" class="dialog-footer">
  86. <el-button @click="dialogFormVisible = false">取 消</el-button>
  87. <el-button type="primary" @click="saveOne">确 定</el-button>
  88. </div>
  89. </el-dialog>
  90. <!--删除提示-->
  91. <el-dialog
  92. title="提示"
  93. :visible.sync="dialogVisible"
  94. width="30%"
  95. :before-close="handleClose"
  96. >
  97. <span>真的要删吗?</span>
  98. <div slot="footer" class="dialog-footer">
  99. <el-button @click="dialogVisible = false">取 消</el-button>
  100. <el-button type="primary" @click="deleteOne">确 定</el-button>
  101. </div>
  102. </el-dialog>
  103. <!--分页-->
  104. <div class="block">
  105. <el-pagination
  106. :current-page="param.page"
  107. :page-sizes="[10, 20, 30, 40]"
  108. :page-size="param.size"
  109. layout="total, sizes, prev, pager, next, jumper"
  110. :total="total"
  111. @size-change="handleSizeChange"
  112. @current-change="handleCurrentChange"
  113. />
  114. </div>
  115. </template>
  116. </div>
  117. </template>
  118. <script>
  119. let _app = {
  120. fetchList: function (query) {
  121. return axios({
  122. url: 'https://yapi.tianyunperfect.cn/mock/11/article/list',
  123. method: 'get',
  124. params: query
  125. })
  126. },
  127. fetchOne: function (id) {
  128. return axios({
  129. url: '/article/detail',
  130. method: 'get',
  131. params: {id}
  132. })
  133. },
  134. saveOne: function (data) {
  135. return axios({
  136. url: '/article/save',
  137. method: 'post',
  138. data
  139. })
  140. },
  141. deleteOne: function (id) {
  142. return axios({
  143. url: '/article/delete',
  144. method: 'post',
  145. params: {id}
  146. })
  147. }
  148. }
  149. const vm = new Vue({
  150. el: "#app",
  151. // 计算函数 动态变化的数据
  152. data: {
  153. tableData: [],
  154. // 删除层隐藏
  155. dialogVisible: false,
  156. // 弹出层隐藏
  157. dialogFormVisible: false,
  158. // 弹出层内容
  159. editNews: {
  160. name: '',
  161. email: ''
  162. },
  163. // 弹出层大小
  164. formLabelWidth: '120px',
  165. // 删除使用的id
  166. id: '',
  167. // 查询参数
  168. param: {
  169. name: '',
  170. date: '',
  171. page: 1,
  172. size: 10
  173. },
  174. // 查询返回总条数
  175. total: 0
  176. },
  177. watch: {},
  178. // 计算属性(过滤) 查询功能
  179. computed: {},
  180. mounted: function () {
  181. this.queryList();
  182. },
  183. methods: {
  184. // 修改页面展示数据大小
  185. handleSizeChange(val) {
  186. this.param.size = val
  187. this.queryList()
  188. },
  189. // 修改页码
  190. handleCurrentChange(val) {
  191. this.param.page = val
  192. this.queryList()
  193. },
  194. // 点击编辑,从后台获取数据
  195. editOne(row) {
  196. console.log(row)
  197. _app.fetchOne(row.id).then(res => {
  198. if (res.flag) {
  199. this.editNews = res.data
  200. }
  201. })
  202. this.dialogFormVisible = true
  203. },
  204. // 获取删除行的id
  205. deleteAlert(id) {
  206. this.id = id
  207. this.dialogVisible = true
  208. },
  209. // 删除
  210. deleteOne() {
  211. _app.deleteOne(this.id).then(res => {
  212. if (res.flag) {
  213. this.dialogFormVisible = false
  214. this.queryList()
  215. } else {
  216. alert('删除失败')
  217. }
  218. })
  219. this.dialogVisible = false
  220. },
  221. // 关闭提示框时,提示是否要关闭
  222. handleClose(done) {
  223. this.$confirm('确认关闭?')
  224. .then(() => {
  225. done()
  226. })
  227. .catch(() => {
  228. })
  229. },
  230. // 点击添加按钮清空
  231. createOne() {
  232. this.editNews = {}
  233. this.dialogFormVisible = true
  234. },
  235. // 点击确定后发送请求
  236. saveOne() {
  237. _app.saveOne(this.editNews).then(res => {
  238. if (res.flag) {
  239. this.dialogFormVisible = false
  240. this.queryList()
  241. } else {
  242. this.$message('添加失败')
  243. }
  244. })
  245. },
  246. // 获取数据
  247. queryList() {
  248. _app.fetchList(this.param).then(res => {
  249. this.tableData = res.list;
  250. this.total = res.total;
  251. })
  252. }
  253. },
  254. });
  255. </script>
  256. </body>
  257. </html>