SenWord.vue 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. <style lang="scss">
  2. .preview {
  3. .el-form-item {
  4. margin-bottom: 15px;
  5. }
  6. label,
  7. p {
  8. line-height: 25px !important;
  9. }
  10. }
  11. </style>
  12. <template>
  13. <section>
  14. <p><span>系统管理></span>敏感词管理</p>
  15. <div class="content">
  16. <div class="filter">
  17. <el-form
  18. size="small"
  19. label-width="70px"
  20. :inline="true"
  21. label-position="left"
  22. >
  23. <el-form-item label="">
  24. <el-input
  25. clearable
  26. placeholder="请输入热词"
  27. v-model="form.name"
  28. ></el-input>
  29. </el-form-item>
  30. <el-form-item>
  31. <el-button type="primary" @click="search">搜索</el-button>
  32. </el-form-item>
  33. <el-form-item style="float: right">
  34. <el-button
  35. @click="(dialogVisible = true), (dialogTitle = '新增敏感词')"
  36. type="primary"
  37. >新增敏感词</el-button
  38. >
  39. </el-form-item>
  40. </el-form>
  41. </div>
  42. <el-table
  43. class="table"
  44. :data="list"
  45. height="50vh"
  46. border
  47. v-loading="loading"
  48. default-expand-all
  49. row-key="id"
  50. style="width: 100%"
  51. >
  52. <el-table-column prop="name" width="300" label="关键字">
  53. </el-table-column>
  54. <el-table-column prop="cname" label="编辑人"> </el-table-column>
  55. <el-table-column prop="ctime" label="编辑时间"> </el-table-column>
  56. <el-table-column prop="zip" width="150" label="操作">
  57. <template slot-scope="scope">
  58. <el-button class="del" @click="del(scope.row.id)" type="text"
  59. >删除</el-button
  60. >
  61. </template>
  62. </el-table-column>
  63. </el-table>
  64. <Page
  65. ref="pageButton"
  66. :current="form.page"
  67. :page_size="form.page_size"
  68. :total="total"
  69. @pageChange="gopage"
  70. />
  71. </div>
  72. <el-dialog
  73. :title="dialogTitle"
  74. :close-on-click-modal="false"
  75. :visible.sync="dialogVisible"
  76. >
  77. <el-form size="small" class="preview" :inline="false" label-width="80px">
  78. <el-form-item label="敏感词">
  79. <el-input v-model="form1.name"></el-input>
  80. </el-form-item>
  81. </el-form>
  82. <span slot="footer" class="dialog-footer">
  83. <el-button size="small" type="primary" @click="save">确 定</el-button>
  84. </span>
  85. </el-dialog>
  86. </section>
  87. </template>
  88. <script>
  89. import Page from "../../components/Page";
  90. export default {
  91. components: {
  92. Page,
  93. },
  94. data() {
  95. return {
  96. form: { name: "", page: 1, page_size: 20 },
  97. form1: {},
  98. total: 1,
  99. list: [],
  100. loading: false,
  101. input: "",
  102. dialogVisible: false,
  103. dialogTitle: "",
  104. defaultProps: {},
  105. data: [],
  106. selected: [],
  107. };
  108. },
  109. methods: {
  110. search() {
  111. let parm = this.form;
  112. this.getData();
  113. },
  114. getData() {
  115. var parm = this.form;
  116. this.loading = true;
  117. this.$api.getSenWordList(parm).then((res) => {
  118. this.loading = false;
  119. if(res.data.code != 0){
  120. return
  121. }
  122. let list = res.data.data.list;
  123. this.list = list;
  124. this.total = res.data.data.total;
  125. });
  126. },
  127. gopage(size) {
  128. if (size) {
  129. this.form.page_size = size;
  130. }
  131. this.form.page = this.$refs.pageButton.page;
  132. this.getData();
  133. },
  134. del(id) {
  135. this.$confirm("确定删除吗", "提示", {
  136. type: "warning",
  137. }).then(() => {
  138. this.$api.delSenWord({ id: id }).then((res) => {
  139. this.$message({
  140. message: "删除成功",
  141. type: "success",
  142. });
  143. this.getData();
  144. });
  145. });
  146. },
  147. save() {
  148. let parm = this.form1;
  149. if (parm.id) {
  150. this.$api.updateSenWord(parm).then((res) => {
  151. if (res.data.code == 0) {
  152. this.$message({
  153. type: "success",
  154. message: "保存成功!",
  155. });
  156. this.getData();
  157. } else {
  158. this.$message.error("失败!");
  159. }
  160. });
  161. } else {
  162. this.$api.addSenWord(parm).then((res) => {
  163. if (res.data.code == 0) {
  164. this.$message({
  165. type: "success",
  166. message: "保存成功!",
  167. });
  168. this.getData();
  169. } else {
  170. this.$message.error("失败!");
  171. }
  172. });
  173. }
  174. this.dialogVisible = false;
  175. },
  176. },
  177. created() {
  178. this.getData();
  179. },
  180. };
  181. </script>