CSS模板语法修复总结

🐛 修复的问题

1. :class中的方法调用语法错误

问题 :uni-app不支持在:class中直接调用方法

复制代码
<!-- ❌ 错误写法 -->
:class="getEfficiencyClass(peak.efficiency)"

解决方案:使用条件对象语法

复制代码
<!-- ✅ 正确写法 -->
:class="{
  'efficiency-excellent': peak.efficiency >= 90,
  'efficiency-good': peak.efficiency >= 80 && peak.efficiency < 90,
  'efficiency-normal': peak.efficiency >= 70 && peak.efficiency < 80,
  'efficiency-poor': peak.efficiency < 70
}"

2. 新能源车牌判断

问题:方法调用语法

复制代码
<!-- ❌ 错误写法 -->
:class="isNewEnergyPlate(item.plateNumber) ? 'green-plate' : 'blue-plate'"

解决方案:直接使用条件表达式

复制代码
<!-- ✅ 正确写法 -->
:class="item.plateNumber && item.plateNumber.length === 8 ? 'green-plate' : 'blue-plate'"

3. 紧急程度类名

问题:字符串拼接语法

复制代码
<!-- ❌ 错误写法 -->
:class="'urgency-' + getWaitingUrgencyLevel(item.recordTime)"

解决方案:使用方法返回完整类名

复制代码
<!-- ✅ 正确写法 -->
:class="getUrgencyClass(item.recordTime)"

对应的方法:

复制代码
getUrgencyClass(recordTime) {
  const urgencyLevel = this.getWaitingUrgencyLevel(recordTime);
  return `urgency-${urgencyLevel}`;
}

📝 修复清单

✅ 已修复的文件

  • pages/site/facility.vue

✅ 修复的语法问题

  1. 效率等级类名:从方法调用改为条件对象
  1. 车牌颜色判断:从方法调用改为直接条件判断
  1. 紧急程度类名:从字符串拼接改为方法返回完整类名

✅ 移除的不必要方法

  • getEfficiencyClass() - 已用条件对象替代

✅ 新增的辅助方法

  • getUrgencyClass() - 返回完整的紧急程度类名

🎯 uni-app模板语法最佳实践

1. :class绑定推荐写法

条件类名

复制代码
:class="{ 'active': isActive, 'disabled': isDisabled }"

三元表达式

复制代码
:class="condition ? 'class-a' : 'class-b'"

数组语法

复制代码
:class="[baseClass, { 'active': isActive }]"

2. 避免的写法

不要在模板中调用复杂方法

复制代码
:class="getComplexClassName(param1, param2)"

不要使用字符串拼接

复制代码
:class="'prefix-' + dynamicValue"

不要使用复杂的计算

复制代码
:class="items.filter(item => item.active).length > 0 ? 'has-active' : ''"

3. 推荐的替代方案

使用计算属性

复制代码
computed: {
  complexClassName() {
    return this.getComplexClassName(this.param1, this.param2);
  }
}

使用简单方法返回完整类名

复制代码
methods: {
  getStatusClass(status) {
    return `status-${status}`;
  }
}

使用条件对象

复制代码
:class="{
  'status-active': item.status === 'active',
  'status-pending': item.status === 'pending',
  'status-disabled': item.status === 'disabled'
}"
相关推荐
m0_613856291 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios7941 小时前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1371 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
abcnull1 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
叶小鸡1 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
@PHARAOH1 小时前
WHAT - GitLens vs Fork
前端
收获不止数据库1 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
yqcoder2 小时前
前端性能优化:如何减少重绘与重排?
前端·性能优化
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
小宇的天下2 小时前
Virtuoso GUI 界面中的关键模块定义
数据库