vue3 两份json数据对比不同的页面给于颜色标识

两份数据对比,新的跟旧的数据不一样页面就给于颜色标识

1. 给每个表单控件添加动态样式标识 :class="hasChanged(字段名称)"

javascript 复制代码
 <div class="container">
    <el-row>
      <el-col :span="12">
        <el-form :model="form" label-width="auto" style="max-width: 600px">
          <el-form-item label="Activity name">
            <el-input v-model="form.name" :class="hasChanged('name')"/>
          </el-form-item>
          <el-form-item label="Activity zone">
            <el-select v-model="form.region" placeholder="please select your zone" :class="hasChanged('region')">
              <el-option label="Zone one" value="shanghai" />
              <el-option label="Zone two" value="beijing" />
            </el-select>
          </el-form-item>
          <el-form-item label="Activity">
            <el-input v-model="form.activity" :class="hasChanged('activity')"/>
          </el-form-item>
          <el-form-item label="Instant delivery">
            <el-switch v-model="form.delivery" :class="hasChanged('delivery')"/>
          </el-form-item>
          <el-form-item label="Resources">
            <el-radio-group v-model="form.resource" :class="hasChanged('resource')">
              <el-radio value="Sponsor">Sponsor</el-radio>
              <el-radio value="Venue">Venue</el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="Activity form">
            <el-input v-model="form.desc" type="textarea" :class="hasChanged('desc')" />
          </el-form-item>
        </el-form>
      </el-col>
      <!-- 第二个 -->
      <el-col :span="12">
        <el-form :model="form2" label-width="auto" style="max-width: 600px">
          <el-form-item label="Activity name">
            <el-input v-model="form2.name"/>
          </el-form-item>
          <el-form-item label="Activity zone">
            <el-select v-model="form2.region" placeholder="please select your zone">
              <el-option label="Zone one" value="shanghai" />
              <el-option label="Zone two" value="beijing" />
            </el-select>
          </el-form-item>
          <el-form-item label="Activity">
            <el-input v-model="form2.activity"/>
          </el-form-item>
          <el-form-item label="Instant delivery">
            <el-switch v-model="form2.delivery" />
          </el-form-item>
          <el-form-item label="Resources">
            <el-radio-group v-model="form2.resource">
              <el-radio value="Sponsor">Sponsor</el-radio>
              <el-radio value="Venue">Venue</el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="Activity form">
            <el-input v-model="form2.desc" type="textarea" />
          </el-form-item>
        </el-form>
      </el-col>
    </el-row>
  </div>

2. 两份数据进行对比 如果想同的话 以字段名为key 添加 markData[字段名] = { status: 'hasChanged' } 不相同的话 添加 markData[字段名] = { status: 'noChanged' }

javascript 复制代码
// 新的
const form = ref({
  name: '',
  region: '',
  activity: '',
  delivery: false,
  resource: '',
  desc: '',
})
// 老的
const form2 = ref({
  name: '',
  region: '',
  activity: '',
  delivery: false,
  resource: '',
  desc: '',
})
// 新的数据
 const newData = {
   name: 'test',
   region: 'test',
   activity: 'testst',
   delivery: false,
   resource: 'Sponsor',
   desc: 'asddasdasd',
 }
// 老的数据
 const oldData = {
   name: 'test1',
   region: 'test',
   activity: 'testst',
   delivery: true,
   resource: 'Sponsor',
   desc: 'asddasdasd11',
 }

3. 对比方法

javascript 复制代码
// 对比后生成新的数据
const compareData = ref({})
// 对比方法
const compareFun = (newData, oldData) => {
  const dataA = { ...newData }
  const dataB = { ...oldData }
  const markData = {}
  Object.keys(dataA).forEach((key) => {
    markData[key] = {}
    if (dataA[key] !== dataB[key]) {
      markData[key] = { status: 'hasChanged'}
    } else {
      markData[key] = { status: 'noChanged'}
    }
  })
  compareData.value = markData
}

4. 使用计算属性给每个表单控件添加对应的class

javascript 复制代码
const hasChanged = computed(() => (key) => {
  if (!compareData.value[key]) return ''
  return compareData.value[key].status
})

5. 对比差异的数据给于颜色标识样式

javascript 复制代码
.hasChanged {
  :deep(.el-input__wrapper) {
    background-color: #f2ac51;
  }
  :deep(.el-input__inner) {
    color: #d9001b;
  }
  :deep(.el-select__wrapper) {
    background-color: #f2ac51;
  }
  :deep(.el-select__placeholder) {
    color: #d9001b;
  }
  :deep(.el-textarea__inner) {
    background-color: #f2ac51;
    color: #d9001b;
  }
  :deep(.el-switch__core) {
    background-color: #f2ac51;
  }
  :deep(.el-radio) {
    background-color: #f2ac51;
  }
}
相关推荐
LYFlied42 分钟前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
爱喝白开水a1 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
董世昌411 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
B站_计算机毕业设计之家1 小时前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
数据知道2 小时前
PostgreSQL实战:详解如何用Python优雅地从PG中存取处理JSON
python·postgresql·json
吃杠碰小鸡2 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone2 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09012 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农3 小时前
Vue 2.3
前端·javascript·vue.js
夜郎king3 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落