vue中$set的使用(結合在實際應用中遇到的坑)


最近在開發過程中遇到一個問題。在節點上面寫點擊事件時,點擊事件不執行。代碼如下:

<!-- 操作 -->
        <el-table-column  label="操作">
          <template slot-scope="scope">
            <span class="poi icon-hover f16 mr20" @click='scope.row.edit=!scope.row.edit'>
              <svg-icon :icon-class="scope.row.edit?'icon_edit_outline':'icon_save'"></svg-icon>
            </span>
            <span class="poi icon-hover f16">
              <svg-icon icon-class="icon_delete"></svg-icon>
            </span>
          </template>
        </el-table-column>
        <!-- 操作 -->

這里面的click事件一直不執行,一開始以為是點擊事件沒寫對一直在找原因,后面突然想到會不會是數據不同步的原因的,因為edit字段是自己添加進去的字段,如下:

export default {
  name: 'strategic',
  data() {
    return {
      tableData: [{
        'pp_id': 4,
        'brand_name': '1414', 
        'project_name': '得意', 
        'description': '的u會回來會', 
        'publish_time': '2018-07-23',
        'is_used': 0 
      }]
    }
  },
  components: { },
  computed: {
  },
  created() {
    this.initTableData()
  },
  methods: {
    initTableData() {
      this.tableData.forEach(element => {
        element.edit = false
      })
    }
  }
}

之后我直接在數據里面加上edit字段,發現是能夠同步數據的,代碼如下:

data() {
    return {
      tableData: [{
        'pp_id': 4,
        'brand_name': '1414',
        'project_name': '1414',
        'description': '7588888888',
        'publish_time': '2018-07-23',
        'is_used': 0,
        'edit': false
      }]
    }
 }    

原來是在我們使用vue進行開發,當生成vue示例后,再次給數據賦值時,有時候並不能自動更新到數據上去,這時候我們就要通過$set來解決這個問題,解決代碼如下:

initTableData() {
  this.tableData.forEach(element => {
      this.$set(element, 'edit', false)
  })
}

至此就解決啦。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM