求教:vue中的find()函数的用法&this.$set

需求:为了实现联动,当我在选择问题标题之后,后面几列的内容就会自动联动显示

方案一: 选完之后 直接 是this.questionList[index] = this.selected;

这样的效果虽然改动了数组,但是页面上没有显示出来实际数组的内容

于是改成了 this.$set(this.questionList,index,this.selected);

于是出现了第二种bug:

第一次选择还是正常的,第二次选择下拉框里面的内容 第一次选择项的id就会被替换掉

整个下拉框的options 内容变动了。就发生了如此神奇的事情。

复制代码
<el-table
          v-loading="loading"
          :data="questionList"
          @selection-change="handleSelectionChange"
        >
          <el-table-column
            label="问题标题"
            align="center"
            prop="title"
            width="250px"
          >
            <template slot-scope="scope">
              <el-select
                v-model="scope.row.id"
                placeholder=""
                clearable
                size="small"
                style="width: 200px"
                filterable  
                @change="selectQuestionChange(scope.$index, scope.row)"
              >
                <el-option
                  v-for="dict in questionOptions"
                  :key="`unique-${dict.id}-${dict.title}`"
                  :label="`${dict.id}-${dict.title}`"
                  :value="dict.id"
                />
              </el-select>
            </template>
          </el-table-column>

........................

下拉框里面的selectQuestionChange方法如下:

复制代码
selectQuestionChange(index, val) { 
      let selected = null;
      let options =[...this.questionOptions];
      if (val.id > "") {
        selected =options.findIndex((item) =>{ return item.id === val.id });
        
        this.selected = this.questionOptions[selected];
           this.$set(this.questionList,index,selected);
      } else {
        selected = {
          id: null,
          title: null,
          basis: null,
          isPitfall: null,
          isImportant: null,
          correction: null,
          createdTime: null,
          isDeleted: null,
        };
         this.$set(this.questionList,index,selected);
      }  

于是最终的解决方案就是 表格数组里的对象的值,都一个个进行对应的赋值

复制代码
        this.questionList[index].isPitfall = this.selected.isPitfall;
        this.questionList[index].isImportant = this.selected.isImportant;
        this.questionList[index].basis = this.selected.basis;
        this.questionList[index].correction = this.selected.correction;
相关推荐
oak隔壁找我几秒前
JavaScript 的函数方法apply、call和bind
javascript
HashTang2 分钟前
【AI 编程实战】第 5 篇:Pinia 状态管理 - 从混乱代码到优雅架构
前端·vue.js·ai编程
青莲8432 分钟前
Kotlin Flow 深度探索与实践指南——上部:基础与核心篇
android·前端
Bug生活20484 分钟前
五年断更,AI助我半天复活小程序
前端·微信小程序·ai编程
狗头大军之江苏分军4 分钟前
Node.js 性能优化实践,但老板只关心是否能跑
前端·后端
恋猫de小郭9 分钟前
2025 年终醒悟,AI 让我误以为自己很强,未来程序员的转型之路
android·前端·flutter
用泥种荷花12 分钟前
【前端学习AI】PromptTemplate的使用
前端
狗头大军之江苏分军14 分钟前
Node.js 真香,但每次部署都想砸电脑
前端·javascript·后端
2501_9462243115 分钟前
旅行记录应用关于应用 - Cordova & OpenHarmony 混合开发实战
javascript·harmonyos·harvester
Shi_haoliu19 分钟前
inno setup6.6.1实例,制作安装包,创建共享文件夹,写入注册表(提供给excel加载项,此文章解释iss文件)
前端·vue.js·windows·excel