vue响应式数据-修改对象的属性值,视图不更新

如图:

一:问题是:

我把数据处理后能console.log()打印出来,但是页面的内容不能同步的更新渲染;

二:要求:

在数组循环列表里面,我点击单个的item按钮时,需要实时加载进度条到90%,并改变item的flowStatus值同时在页面上渲染当前改变后的状态值。

三:方式:

用了$delete()先删除这个已经存在并且要改变的键值flowStatus;

this.$delete(flow,'flowStatus')

再$set()重新赋值flowStatus为我需要的状态值:

this.$set(flow,'flowStatus','0')

进度条加载一样。。。

四:代码

javascript 复制代码
        <el-row v-for="(flow,i) in item.children" :key="flow.flowId" class="flowinfo">
          <el-col :span="10" :offset="1"  style="">
            <div>
              <template>
                <el-tag v-if="flow.flowStatus === 10 || flow.flowStatus === 20" color="#red">{{'等待中'}}</el-tag>
                <el-tag v-if="flow.flowStatus === '0'"  color="#E9EAAC">{{'启动中...'}}</el-tag>
              </template>
            </div>
            <div class="flow">
              <el-row>
                <el-col v-if="flow.flowStatus === 30" :span="15" :offset="2">任务进度:<el-progress :percentage="90" :key="i" :format="format" top="20px"></el-progress></el-col>
                <el-col v-else :span="15" :offset="2">任务进度:<el-progress :percentage="flow.percentage" :key="i" :format="format" top="20px"></el-progress></el-col>
              </el-row>
            </div>
          </el-col>
          <el-col :span="10" :offset="1">
            <div style="padding-bottom: 30px;" >
              <el-button v-else style="float: right;" type="primary" size="mini" @click="start(flow)" >{{ '启动' }}</el-button>
            </div>
          </el-col>
        </el-row>

启动按钮

主要看前面几行:有注释的

点击某条列表的按钮后,该对象里面的状态值flowStatus由a变为b,进度条自己加载到90%

javascript 复制代码
    start(flow) {
      this.$nextTick(() => {
        this.$delete(flow,'flowStatus')          //先删掉对象里的flowStatus值
        this.$set(flow,'flowStatus','0')         //再新增flowStatus值为0  (第一个值为要改变的对象,第二个为要改的键名,第三个为改后的键值)
        if(flow.percentage < 100) {              //这是进度条的变化
          this.$delete(flow,'percentage')        //删掉对象里的percentage
          this.$set(flow, 'percentage', 90);      //  再新设置percentage值,使其发生变化为90
        }
        this.$forceUpdate()
        setTimeout(() => {
          let username = storage.get("baseInfo", "local") ? storage.get("baseInfo", "local").username : null;
          const queryForm = {
            projectId: projectId,
            ...
          }
          startExecutor(queryForm).then(res => {
            if(res.code === "200") {
              this.$message.success('执行成功')
            } else {
              this.$notify({
                title: '执行错误',
                message: res.message,
                type: 'warning'
              });
            }
            setTimeout(() => {
              this.getTaskList(this.taskData)
            }, 1000);
          })
        }, 3000);
      })
    },

点击改变的是里面的flowStatus和percentage

item.children=[

{

"execFlowList": [

{

"runDate": "20241205",

"submitTime": 1733469100453,

"submitUser": "hadoop",

"difftime": "0 sec",

"startTime": "2024-12-06 15:11:40",

"comment": "",

"endTime": "2024-12-06 15:11:40",

"flowId": "defence",

"projectId": 6,

"outTime": "0 sec",

"execId": 230,

"status": "FAILED"

}

],

"percentage": 0,

"flowExecId": 230,

"flowStatus": 70,

"flowId": "defence"

}...

]

相关推荐
iReachers2 小时前
WebView2与Chrome内核的区别和使用场景详细介绍
前端·chrome·webview2
困顿小狗3 小时前
vue2 项目webpack 4升5
前端·webpack
sleeppingfrog3 小时前
vue3中自定义组件的双向绑定
前端·javascript·vue.js
Domain-zhuo4 小时前
uniapp 应用的生命周期、页面的生命周期、组件的生命周期
前端·javascript·vue.js·前端框架·uni-app·html·ecmascript
旅行中的伊蕾娜4 小时前
uniapp炫酷导航按钮及轮播指示器组件
前端·javascript·vue.js·微信小程序·uni-app
Liberty_yes4 小时前
uniapp navigateTo、redirectTo、reLaunch等页面路由跳转方法的区别
前端·uni-app
cy玩具4 小时前
Vuex在uniapp中的使用
开发语言·javascript·ecmascript
yunfanleo4 小时前
npm、yarn、pnpm 设置最新国内镜像源(附官方镜像源和最新阿里源)
vue.js
振华OPPO4 小时前
VS Code使用NPM脚本启动Vue程序
前端·vue.js·vscode·npm·node.js·vue