elementui mysql设置图标,element-ui 的el-button组件中添加自定义颜色和图标的实现方法...

本文介绍如何在Element-UI的el-button组件中添加自定义颜色和图标。通过创建自定义全局指令和修改Element-UI源码,开发人员可以在type属性中指定不同类别,以显示不同颜色和图标。此外,还展示了如何使用自定义图标来替换Element-UI默认图标库中的图标。
摘要由CSDN通过智能技术生成

这篇文章主要介绍了element-ui 的el-button组件中添加自定义颜色和图标的实现方法,目前的解决方案是:添加一个自定义全局指令,同时在element-ui源码中,加入对应的组件。需要的朋友跟随小编一起看看吧

我使用的element-ui的版本是V1.4.13。

d3d900a5430f4191319901c91748829b.png

如上图所示,如果使用el-button,加颜色是可以通过设置type属性的值,加图标就设置icon属性的值。

现在产品给了一个需求,就是自定义的很多种类别,不同的类别的按钮显示不同的颜色和图标。如下图所示:

a9c0cf938973b122d90d8144fa685b7f.png

为了方便开发,目前的解决方案是:添加一个自定义全局指令,同时在element-ui源码中,加入对应的组件。开发人员在开发时只要在type中添加不同的类的值,就能添加上颜色和图标。

1、在element-ui的button源码中加了自定义指令otherRender,以及一个局部组件vRender

f626b238ed175d62371687b372ef8575.png

2、局部组件vRender的写法:

bbc207b502504b0a6824a722be220572.png

00435c4994990ec3f418aa653e39142f.png

3、自定义指令otherRender,写在项目公共的js中。这里我先将所有的类对应的颜色类和图标定义好。css样式是根据需求自定义的

75a6a9c65add9e8b40ba74e532fe4831.png

然后再在指令中循环添加

6027b361b8636d1a746b2cb9812ea821.png

在使用el-button时只要添加对应的type值就能使用,对应的颜色和图标就会显示了

下面看下自定义elementui中的图标

前提

elementui图标库图标较少

当你想用elementui的控件而不想用它的图标时,就可以使用自定义的方式来实现

实现

el-icon-my-export为我自定义的图标命名

导出

//使用图片来替换//before属性中的content文本是用来占位的,必须有//可以设置字体大小来确定大小//使用visibility: hidden;来隐藏文字

.el-icon-my-export{

background: url(/officeHouse/resources/images/export.png) center no-repeat;

background-size: cover;

}

.el-icon-my-export:before{

content:"替";

font-size: 16px;

visibility: hidden;

}//如果直接使用字体图片//直接在before属性设置对应的content就行

.el-icon-my-export{

font-size: 16px;

}

.el-icon-my-export:before{

content:"\e611";

}

content里面使用汉字大小会比较正常,但是汉字有时候会出现乱码,可以使用Unicode编码//编码后的的替为 \u66ff//书写到css里面的时候需要去掉u

.el-icon-my-export:before{

content:"\66ff";

font-size: 16px;

visibility: hidden;

}

其他控件的图标替换大多如此,当然具体问题具体分析,我也不确定会不会有不同的情况

很高兴能为您提供这方面的帮助,以下是基本的代码结构和技术选型: ## 后端代码结构 ``` ├── src │ ├── main │ │ ├── java │ │ │ ├── com │ │ │ │ ├── example │ │ │ │ │ ├── config │ │ │ │ │ │ ├── MybatisPlusConfig.java │ │ │ │ │ │ ├── WebMvcConfig.java │ │ │ │ │ ├── controller │ │ │ │ │ │ ├── TeacherController.java │ │ │ │ │ ├── dao │ │ │ │ │ │ ├── TeacherDao.java │ │ │ │ │ ├── entity │ │ │ │ │ │ ├── Teacher.java │ │ │ │ │ ├── service │ │ │ │ │ │ ├── TeacherService.java │ │ │ │ │ │ ├── impl │ │ │ │ │ │ │ ├── TeacherServiceImpl.java │ │ │ │ │ ├── Application.java │ │ │ │ ├── common │ │ │ │ │ ├── Result.java │ │ │ │ ├── interceptor │ │ │ │ │ ├── LoginInterceptor.java │ │ │ │ ├── mapper │ │ │ │ │ ├── TeacherMapper.java │ │ │ │ ├── utils │ │ │ │ │ ├── JwtUtils.java │ │ ├── resources │ │ │ ├── application.yml │ │ │ ├── mapper │ │ │ │ ├── TeacherMapper.xml │ │ ├── static │ │ ├── templates ``` ## 技术选型 - 后端技术栈:Spring Boot、Mybatis-Plus、JWT、MySQL - 前端技术栈:Vue、Element UI、Axios ## 后端代码实现 ### 配置文件 在 `application.yml` 配置数据库和 JWT 相关信息。 ```yaml server: port: 8080 spring: datasource: url: jdbc:mysql://localhost:3306/teacher_evaluation?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver mybatis-plus: mapper-locations: classpath:mapper/*.xml type-aliases-package: com.example.entity configuration: map-underscore-to-camel-case: true jwt: secret: secret expire: 3600 ``` ### 实体类 ```java @Data public class Teacher { private Integer id; private String name; private Integer age; private String sex; private String phone; private String email; private String address; private Integer departmentId; private Integer status; } ``` ### Mapper 接口 ```java public interface TeacherMapper extends BaseMapper<Teacher> { } ``` ### DAO 层 ```java public interface TeacherDao { Teacher selectById(Integer id); List<Teacher> selectList(); int insert(Teacher teacher); int update(Teacher teacher); int delete(Integer id); } ``` ### Service 层 ```java public interface TeacherService { Teacher selectById(Integer id); List<Teacher> selectList(); boolean save(Teacher teacher); boolean update(Teacher teacher); boolean delete(Integer id); } ``` ### Service 实现类 ```java @Service public class TeacherServiceImpl implements TeacherService { @Autowired private TeacherDao teacherDao; @Override public Teacher selectById(Integer id) { return teacherDao.selectById(id); } @Override public List<Teacher> selectList() { return teacherDao.selectList(); } @Override public boolean save(Teacher teacher) { return teacherDao.insert(teacher) > 0; } @Override public boolean update(Teacher teacher) { return teacherDao.update(teacher) > 0; } @Override public boolean delete(Integer id) { return teacherDao.delete(id) > 0; } } ``` ### Controller 层 ```java @RestController @RequestMapping("/teacher") public class TeacherController { @Autowired private TeacherService teacherService; @GetMapping("/list") public Result list() { List<Teacher> list = teacherService.selectList(); return Result.success(list); } @PostMapping("/save") public Result save(@RequestBody Teacher teacher) { boolean result = teacherService.save(teacher); return result ? Result.success() : Result.fail("添加失败"); } @PostMapping("/update") public Result update(@RequestBody Teacher teacher) { boolean result = teacherService.update(teacher); return result ? Result.success() : Result.fail("更新失败"); } @PostMapping("/delete") public Result delete(@RequestParam Integer id) { boolean result = teacherService.delete(id); return result ? Result.success() : Result.fail("删除失败"); } } ``` ### JWT 鉴权 ```java @Component public class LoginInterceptor implements HandlerInterceptor { @Autowired private JwtUtils jwtUtils; @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String token = request.getHeader("Authorization"); if (token == null || !token.startsWith("Bearer ")) { throw new RuntimeException("无效的token"); } token = token.replace("Bearer ", ""); if (!jwtUtils.validateToken(token)) { throw new RuntimeException("无效的token"); } return true; } } ``` ## 前端代码实现 ### Axios 请求封装 ```js import axios from 'axios' import { Message } from 'element-ui' let instance = axios.create({ baseURL: '/api', timeout: 5000, headers: { 'Content-Type': 'application/json;charset=UTF-8' } }) instance.interceptors.request.use(config => { let token = localStorage.getItem('token') if (token) { config.headers.Authorization = `Bearer ${token}` } return config }, error => { return Promise.reject(error) }) instance.interceptors.response.use(response => { if (response.status === 200) { return response.data } else { Message.error('请求错误') } }, error => { if (error.response.status === 401) { Message.error('登录过期') localStorage.removeItem('token') window.location.href = '/login' } else if (error.response.status === 403) { Message.error('权限不足') } else if (error.response.status === 500) { Message.error('服务器错误') } else { Message.error('请求错误') } return Promise.reject(error) }) export default instance ``` ### Vue 页面 ```vue <template> <div> <el-row> <el-col :span="24"><h2>教师列表</h2></el-col> </el-row> <el-row> <el-col :span="24"><el-button type="primary" @click="add">添加教师</el-button></el-col> </el-row> <el-row> <el-col :span="24"> <el-table :data="tableData" style="width: 100%"> <el-table-column prop="id" label="ID"></el-table-column> <el-table-column prop="name" label="姓名"></el-table-column> <el-table-column prop="age" label="年龄"></el-table-column> <el-table-column prop="sex" label="性别"></el-table-column> <el-table-column prop="phone" label="电话"></el-table-column> <el-table-column prop="email" label="邮箱"></el-table-column> <el-table-column prop="address" label="地址"></el-table-column> <el-table-column prop="departmentId" label="部门"></el-table-column> <el-table-column prop="status" label="状态"></el-table-column> <el-table-column label="操作"> <template slot-scope="scope"> <el-button type="primary" size="mini" @click="edit(scope.row)">编辑</el-button> <el-button type="danger" size="mini" @click="remove(scope.row)">删除</el-button> </template> </el-table-column> </el-table> </el-col> </el-row> <el-dialog title="添加教师" :visible.sync="addDialogVisible"> <el-form :model="addForm" :rules="addRules" ref="addForm"> <el-form-item label="姓名" prop="name"> <el-input v-model="addForm.name"></el-input> </el-form-item> <el-form-item label="年龄" prop="age"> <el-input v-model="addForm.age"></el-input> </el-form-item> <el-form-item label="性别" prop="sex"> <el-radio-group v-model="addForm.sex"> <el-radio label="男"></el-radio> <el-radio label="女"></el-radio> </el-radio-group> </el-form-item> <el-form-item label="电话" prop="phone"> <el-input v-model="addForm.phone"></el-input> </el-form-item> <el-form-item label="邮箱" prop="email"> <el-input v-model="addForm.email"></el-input> </el-form-item> <el-form-item label="地址" prop="address"> <el-input v-model="addForm.address"></el-input> </el-form-item> <el-form-item label="部门" prop="departmentId"> <el-select v-model="addForm.departmentId"> <el-option v-for="item in departmentList" :key="item.value" :label="item.label" :value="item.value"></el-option> </el-select> </el-form-item> </el-form> <div slot="footer"> <el-button @click="addDialogVisible = false">取消</el-button> <el-button type="primary" @click="addFormSubmit">添加</el-button> </div> </el-dialog> <el-dialog title="编辑教师" :visible.sync="editDialogVisible"> <el-form :model="editForm" :rules="editRules" ref="editForm"> <el-form-item label="ID" prop="id"> <el-input v-model="editForm.id" disabled></el-input> </el-form-item> <el-form-item label="姓名" prop="name"> <el-input v-model="editForm.name"></el-input> </el-form-item> <el-form-item label="年龄" prop="age"> <el-input v-model="editForm.age"></el-input> </el-form-item> <el-form-item label="性别" prop="sex"> <el-radio-group v-model="editForm.sex"> <el-radio label="男"></el-radio> <el-radio label="女"></el-radio> </el-radio-group> </el-form-item> <el-form-item label="电话" prop="phone"> <el-input v-model="editForm.phone"></el-input> </el-form-item> <el-form-item label="邮箱" prop="email"> <el-input v-model="editForm.email"></el-input> </el-form-item> <el-form-item label="地址" prop="address"> <el-input v-model="editForm.address"></el-input> </el-form-item> <el-form-item label="部门" prop="departmentId"> <el-select v-model="editForm.departmentId"> <el-option v-for="item in departmentList" :key="item.value" :label="item.label" :value="item.value"></el-option> </el-select> </el-form-item> </el-form> <div slot="footer"> <el-button @click="editDialogVisible = false">取消</el-button> <el-button type="primary" @click="editFormSubmit">保存</el-button> </div> </el-dialog> </div> </template> <script> import api from '@/utils/api' export default { name: 'TeacherList', data() { return { tableData: [], addDialogVisible: false, addForm: { name: '', age: '', sex: '男', phone: '', email: '', address: '', departmentId: '' }, addRules: { name: [ { required: true, message: '请输入姓名', trigger: 'blur' }, { min: 2, max: 20, message: '长度在 2 到 20 个字符', trigger: 'blur' } ], age: [ { required: true, message: '请输入年龄', trigger: 'blur' }, { type: 'number', message: '年龄必须为数字', trigger: 'blur' } ], sex: [ { required: true, message: '请选择性别', trigger: 'change' } ], phone: [ { required: true, message: '请输入电话', trigger: 'blur' }, { pattern: /^1[3456789]\d{9}$/, message: '手机号码格式不正确', trigger: 'blur' } ], email: [ { required: true, message: '请输入邮箱', trigger: 'blur' }, { type: 'email', message: '邮箱格式不正确', trigger: 'blur' } ], address: [ { required: true, message: '请输入地址', trigger: 'blur' } ], departmentId: [ { required: true, message: '请选择所属部门', trigger: 'change' } ] }, editDialogVisible: false, editForm: { id: '', name: '', age: '', sex: '男', phone: '', email: '', address: '', departmentId: '' }, editRules: { name: [ { required: true, message: '请输入姓名', trigger: 'blur' }, { min: 2, max: 20, message: '长度在 2 到 20 个字符', trigger: 'blur' } ], age: [ { required: true, message: '请输入年龄', trigger: 'blur' }, { type: 'number', message: '年龄必须为数字', trigger: 'blur' } ], sex: [ { required: true, message: '请选择性别', trigger: 'change' } ], phone: [ { required: true, message: '请输入电话', trigger: 'blur' }, { pattern: /^1[3456789]\d{9}$/, message: '手机号码格式不正确', trigger: 'blur' } ], email: [ { required: true, message: '请输入邮箱', trigger: 'blur' }, { type: 'email', message: '邮箱格式不正确', trigger: 'blur' } ], address: [ { required: true, message: '请输入地址', trigger: 'blur' } ], departmentId: [ { required: true, message: '请选择所属部门', trigger: 'change' } ] }, departmentList: [ { value: 1, label: '计算机科学与技术' }, { value: 2, label: '信息管理与信息系统' }, { value: 3, label: '软件工程' } ] } }, created() { this.getList() }, methods: { getList() { api.get('/teacher/list').then(res => { this.tableData = res.data }) }, add() { this.addDialogVisible = true }, addFormSubmit() { this.$refs.addForm.validate(valid => { if (valid) { api.post('/teacher/save', this.addForm).then(res => { this.addDialogVisible = false this.getList() }) } }) }, edit(row) { this.editForm = Object.assign({}, row) this.editDialogVisible = true }, editFormSubmit() { this.$refs.editForm.validate(valid => { if (valid) { api.post('/teacher/update', this.editForm).then(res => { this.editDialogVisible = false this.getList() }) } }) }, remove(row) { this.$confirm('确定删除?', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning' }).then(() => { api.post('/teacher/delete', { id: row.id }).then(res => { this.getList() }) }) } } } </script> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值