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'
}"
相关推荐
6极地诈唬11 小时前
【sqlite】xxx.db-journal是什么?
数据库·sqlite
珹洺11 小时前
Java-Spring入门指南(二十七)Android Studio 第一个项目搭建与手机页面模拟器运行
java·spring·android studio
im_AMBER11 小时前
React 01
前端·javascript·笔记·react.js·前端框架·web
@大迁世界12 小时前
React 19.2.0 有哪些新变化
前端·javascript·react.js·前端框架·ecmascript
程序猿DD12 小时前
Java 25 中的 6 个新特性解读
java·后端
稻草猫.12 小时前
文件 IO
java·笔记·后端·java-ee·idea
laopeng30112 小时前
基于Spring AI Deep Researcher Agent
java·人工智能·spring
子豪-中国机器人12 小时前
《C++ STL 基础入门》教案
java·开发语言
java_t_t12 小时前
集合工具类
java·集合
亮子AI12 小时前
【小程序】微信小程序点击效果(view、button、navigator)
微信小程序·小程序