【问题标题】:v-for loop items not immediately updating in Vuev-for 循环项目不会在 Vue 中立即更新
【发布时间】:2018-06-20 06:16:41
【问题描述】:

我将逐点解释,因为它可能是一个安静的复杂。

  • 我用鼠标或触控板突出显示文本,在 mouseup 上突出显示的文本存储在对象数组中。每个对象都包含选定的文本。

  • 我希望在该数组上循环,以便能够一一显示所有选择,只要我选择不同的文本。

基本上,我将每个选定的文本存储到 selectionArray。每个 selectedText 都是对象内的字符串。所以 SelectionArray 变成了这样的对象数组在第一次选择时:

[
 {selectedText: '...string...'}
]

在第二次选择时,数组被更新:

[
 {selectedText: '...string...'},
 {selectedText: '...another string...'}
]

等等…… 最后,我在等于 selectionArray 的 items 数组上使用 v-on 循环 与:

this.items = selectionArray

目前我快到了,但缺少一些东西,因为我没有看到实时修改我必须对 HTML 进行无用的修改(奇怪),例如才能看到结果。我怀疑创建的方法,但我需要帮助,至少是一种逻辑的调查方式。谢谢

代码如下:

<template>
  <main class='wrapper'>
    <section class='wrapper-copy'>
      <div class='copy'>
Lorem ipsum dolor sit amet consectetur adipisicing elit. Omnis sequi dolorum soluta pariatur asperiores. Recusandae atque nesciunt ipsa velit impedit fugit enim, quia explicabo adipisci sunt earum laudantium illo. Tenetur.
Animi magnam corrupti atque mollitia eaque enim, voluptatum magni laboriosam vel possimus reprehenderit aut doloribus inventore repellat aliquam voluptatem esse ut saepe at iusto qui quibusdam doloremque exercitationem ipsam. Dicta.
In animi nobis accusamus nemo repellat dicta a repellendus provident accusantium fugit voluptas minus laudantium reiciendis cumque, amet porro maiores quisquam? Ullam aut voluptatem delectus cum rerum perferendis vero laudantium!
      </div>

    </section>
    <article class="wrapper-select">
      <div class="select">
        <div id='input'
             class='selected-copy'
             v-for='(item, index) in items' 
             :key='item.index'>
          <div class='index'>{{ index }} </div>
          <p class='selection'> {{ item.selectedText }} </p>
        </div>
      </div>
    </article>
  </main>
</template>

<script>
  export default {
    name: 'app',
    data () {
      return {
        items: []
      }
    },
    created () {
      var selectionArray = []
      function storeSelection () {
        var selectedText = window.getSelection().toString()
        if (selectedText.length && selectionArray.indexOf(selectedText) === -1) {
          selectionArray[selectionArray.length] = {selectedText}
        }
        console.log(selectionArray)
      }
      document.addEventListener('mouseup', storeSelection)
      this.items = selectionArray
      console.log(this.items)
    }
  }
</script>

【问题讨论】:

  • 很难理解,你的意思。如果您想一一显示选择,为什么不添加 setTimeout 或 setInterval?还记得 vuejs 的 nexttick 特性吗?
  • @shukshin.ivan 抱歉解释不好,感谢您抽出宝贵时间。我现在将编辑我的问题,请告诉我它是否更好
  • @shukshin.ivan 完成!

标签: javascript arrays vue.js v-for


【解决方案1】:

Vue 无法检测到数组项和对象属性的添加/删除。阅读 Vue 指南的 Caveats 部分,它为您提供了一些关于如何解决该问题的想法。

它是这样说的:

由于 JavaScript 的限制,Vue 无法检测到数组的以下更改:

  1. 当您直接使用索引设置项目时,例如vm.items[indexOfItem] = newValue
  2. 当您修改数组的长度时,例如vm.items.length = newLength

要克服警告 1,以下两项将完成与 vm.items[indexOfItem] = newValue 相同的操作,但也会触发反应系统中的状态更新:

// Vue.set
Vue.set(example1.items, indexOfItem, newValue)

// Array.prototype.splice
example1.items.splice(indexOfItem, 1, newValue)

要处理注意事项 2,您可以使用 splice:

example1.items.splice(newLength)

【讨论】:

  • 感谢您的宝贵时间。这似乎是你正确的问题。该文档没有解释如何以及在何处实施以克服警告。请问有什么建议吗?
  • 是的!它显然提供了一些克服这些警告的方法。我在答案中添加了一些。
  • 谢谢@JakeParis 但仍然不明白如何实现这一点。无论如何都非常感谢。这对我来说是一个巨大的进步:)
猜你喜欢
  • 1970-01-01
  • 2021-05-15
  • 1970-01-01
  • 2023-02-22
  • 2019-12-23
  • 2017-04-03
  • 2019-06-02
  • 2018-10-02
  • 2020-09-03
相关资源
最近更新 更多