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 小时前
作用域链 × 闭包:三段代码,看懂 JavaScript 的套娃人生
前端·javascript
煎蛋学姐4 小时前
SSM旅游资讯信息服务系统的实现04s3n(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·旅游·ssm 框架·旅游资讯系统·会员管理
3***31215 小时前
初识MySQL · 库的操作
数据库·mysql
合作小小程序员小小店5 小时前
网页开发,在线%新版本旅游管理%系统,基于eclipse,html,css,jquery,servlet,jsp,mysql数据库
java·数据库·eclipse·html·intellij-idea·旅游·jsp
anod5 小时前
奇怪的mysql时区问题
数据库·mysql·eclipse
鲸说MySQL5 小时前
MySQL表文件损坏
数据库·mysql
风止何安啊5 小时前
收到字节的短信:Trae SOLO上线了?尝尝鲜,浅浅做个音乐播放器
前端·html·trae
a***59265 小时前
【SQL技术】不同数据库引擎 SQL 优化方案剖析
数据库·sql
组合缺一5 小时前
Spring Boot 国产化替代方案。Solon v3.7.2, v3.6.5, v3.5.9 发布(支持 LTS)
java·后端·spring·ai·web·solon·mcp
抱琴_5 小时前
大屏性能优化终极方案:请求合并+智能缓存双剑合璧
前端·javascript