增加字典标签样式回显
This commit is contained in:
		
							parent
							
								
									60c22b6a43
								
							
						
					
					
						commit
						b1413f021e
					
				
							
								
								
									
										51
									
								
								ruoyi-ui/src/components/DictTag/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								ruoyi-ui/src/components/DictTag/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,51 @@ | ||||
| <template> | ||||
|   <div> | ||||
|     <template v-for="(item, index) in options"> | ||||
|       <template v-if="values.includes(item.dictValue)"> | ||||
|         <span | ||||
|           v-if="item.listClass == 'default' || item.listClass == ''" | ||||
|           :key="item.dictValue" | ||||
|           :index="index" | ||||
|           :class="item.cssClass" | ||||
|           >{{ item.dictLabel }}</span | ||||
|         > | ||||
|         <el-tag | ||||
|           v-else | ||||
|           :key="item.dictValue" | ||||
|           :index="index" | ||||
|           :type="item.listClass == 'primary' ? '' : item.listClass" | ||||
|           :class="item.cssClass" | ||||
|         > | ||||
|           {{ item.dictLabel }} | ||||
|         </el-tag> | ||||
|       </template> | ||||
|     </template> | ||||
|   </div> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| export default { | ||||
|   name: "DictTag", | ||||
|   props: { | ||||
|     options: { | ||||
|       type: Array, | ||||
|       default: null, | ||||
|     }, | ||||
|     value: [String, Array], | ||||
|   }, | ||||
|   computed: { | ||||
|     values() { | ||||
|       if (this.value) { | ||||
|         return Array.isArray(this.value) ? this.value : [this.value]; | ||||
|       } else { | ||||
|         return []; | ||||
|       } | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style scoped> | ||||
| .el-tag + .el-tag { | ||||
|   margin-left: 10px; | ||||
| } | ||||
| </style> | ||||
| @ -86,10 +86,19 @@ | ||||
|     <el-table v-loading="loading" :data="dataList" @selection-change="handleSelectionChange"> | ||||
|       <el-table-column type="selection" width="55" align="center" /> | ||||
|       <el-table-column label="字典编码" align="center" prop="dictCode" /> | ||||
|       <el-table-column label="字典标签" align="center" prop="dictLabel" /> | ||||
|       <el-table-column label="字典标签" align="center" prop="dictLabel"> | ||||
|         <template slot-scope="scope"> | ||||
|           <span v-if="scope.row.listClass == '' || scope.row.listClass == 'default'">{{scope.row.dictLabel}}</span> | ||||
|           <el-tag v-else :type="scope.row.listClass == 'primary' ? '' : scope.row.listClass">{{scope.row.dictLabel}}</el-tag> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column label="字典键值" align="center" prop="dictValue" /> | ||||
|       <el-table-column label="字典排序" align="center" prop="dictSort" /> | ||||
|       <el-table-column label="状态" align="center" prop="status" :formatter="statusFormat" /> | ||||
|       <el-table-column label="状态" align="center" prop="status"> | ||||
|         <template slot-scope="scope"> | ||||
|           <dict-tag :options="statusOptions" :value="scope.row.status"/> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true" /> | ||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> | ||||
|         <template slot-scope="scope"> | ||||
| @ -136,9 +145,22 @@ | ||||
|         <el-form-item label="数据键值" prop="dictValue"> | ||||
|           <el-input v-model="form.dictValue" placeholder="请输入数据键值" /> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="样式属性" prop="cssClass"> | ||||
|           <el-input v-model="form.cssClass" placeholder="请输入样式属性" /> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="显示排序" prop="dictSort"> | ||||
|           <el-input-number v-model="form.dictSort" controls-position="right" :min="0" /> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="回显样式" prop="listClass"> | ||||
|           <el-select v-model="form.listClass"> | ||||
|             <el-option | ||||
|               v-for="item in listClassOptions" | ||||
|               :key="item.value" | ||||
|               :label="item.label" | ||||
|               :value="item.value" | ||||
|             ></el-option> | ||||
|           </el-select> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="状态" prop="status"> | ||||
|           <el-radio-group v-model="form.status"> | ||||
|             <el-radio | ||||
| @ -163,9 +185,14 @@ | ||||
| <script> | ||||
| import { listData, getData, delData, addData, updateData, exportData } from "@/api/system/dict/data"; | ||||
| import { listType, getType } from "@/api/system/dict/type"; | ||||
| // 字典标签组件(使用频繁可在全局挂载) | ||||
| import DictTag from '@/components/DictTag' | ||||
| 
 | ||||
| export default { | ||||
|   name: "Data", | ||||
|   components: { | ||||
|     DictTag | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
| @ -190,6 +217,33 @@ export default { | ||||
|       title: "", | ||||
|       // 是否显示弹出层 | ||||
|       open: false, | ||||
|       // 数据标签回显样式 | ||||
|       listClassOptions: [ | ||||
|         { | ||||
|           value: "default", | ||||
|           label: "默认" | ||||
|         }, | ||||
|         { | ||||
|           value: "primary", | ||||
|           label: "主要" | ||||
|         }, | ||||
|         { | ||||
|           value: "success", | ||||
|           label: "成功" | ||||
|         }, | ||||
|         { | ||||
|           value: "info", | ||||
|           label: "信息" | ||||
|         }, | ||||
|         { | ||||
|           value: "warning", | ||||
|           label: "警告" | ||||
|         }, | ||||
|         { | ||||
|           value: "danger", | ||||
|           label: "危险" | ||||
|         } | ||||
|       ], | ||||
|       // 状态数据字典 | ||||
|       statusOptions: [], | ||||
|       // 类型数据字典 | ||||
| @ -250,10 +304,6 @@ export default { | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     // 数据状态字典翻译 | ||||
|     statusFormat(row, column) { | ||||
|       return this.selectDictLabel(this.statusOptions, row.status); | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false; | ||||
|  | ||||
| @ -123,7 +123,11 @@ | ||||
|           </router-link> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column label="状态" align="center" prop="status" :formatter="statusFormat" /> | ||||
|       <el-table-column label="状态" align="center" prop="status"> | ||||
|         <template slot-scope="scope"> | ||||
|           <dict-tag :options="statusOptions" :value="scope.row.status"/> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true" /> | ||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> | ||||
|         <template slot-scope="scope"> | ||||
| @ -190,9 +194,14 @@ | ||||
| 
 | ||||
| <script> | ||||
| import { listType, getType, delType, addType, updateType, exportType, refreshCache } from "@/api/system/dict/type"; | ||||
| // 字典标签组件(使用频繁可在全局挂载) | ||||
| import DictTag from '@/components/DictTag' | ||||
| 
 | ||||
| export default { | ||||
|   name: "Dict", | ||||
|   components: { | ||||
|     DictTag | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 遮罩层 | ||||
| @ -257,10 +266,6 @@ export default { | ||||
|         } | ||||
|       ); | ||||
|     }, | ||||
|     // 字典状态字典翻译 | ||||
|     statusFormat(row, column) { | ||||
|       return this.selectDictLabel(this.statusOptions, row.status); | ||||
|     }, | ||||
|     // 取消按钮 | ||||
|     cancel() { | ||||
|       this.open = false; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Ricky
						Ricky