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'
}"
相关推荐
豆豆豆大王4 小时前
头歌Kingbase ES内连接、外连接查询
大数据·数据库·elasticsearch
muxin-始终如一5 小时前
MySQL与Redis面试问题详解
数据库·redis·mysql
龙茶清欢5 小时前
7、revision 是 Maven 3.5+ 引入的现代版本管理机制
java·elasticsearch·maven
柯南二号5 小时前
【Java后端】《Spring Boot Starter 原理详解》博客
java·开发语言·spring boot
gihigo19985 小时前
在CentOS上配置SVN至Web目录的自动同步
前端·svn·centos
歪歪1005 小时前
如何在SQLite中实现事务处理?
java·开发语言·jvm·数据库·sql·sqlite
珍宝商店5 小时前
优雅的 async/await 错误处理模式指南
开发语言·前端·javascript
瑶总迷弟5 小时前
静默安装 Oracle Database 21c on CentOS 7.6
数据库·oracle·centos
excel5 小时前
楖览:Vue3 源码研究导读
前端