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'
}"
相关推荐
三小河21 分钟前
Agent Skill与Rules的区别——以Cursor为例
前端·javascript·后端
kali-Myon25 分钟前
2025春秋杯网络安全联赛冬季赛-day1
java·sql·安全·web安全·ai·php·web
Hilaku28 分钟前
不要在简历上写精通 Vue3?来自面试官的真实劝退
前端·javascript·vue.js
我是咸鱼不闲呀28 分钟前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划
三小河34 分钟前
前端视角详解 Agent Skill
前端·javascript·后端
数据知道36 分钟前
PostgreSQL 性能优化:分区表实战
数据库·postgresql·性能优化
清水白石00838 分钟前
深入解析 LRU 缓存:从 `@lru_cache` 到手动实现的完整指南
java·python·spring·缓存
Aniugel1 小时前
单点登录(SSO)系统
前端
鹏多多1 小时前
移动端H5项目,还需要react-fastclick解决300ms点击延迟吗?
前端·javascript·react.js
符哥20081 小时前
C++ 进阶知识点整理
java·开发语言·jvm