>  기사  >  웹 프론트엔드  >  Vue에서 계산된 속성을 사용하는 방법

Vue에서 계산된 속성을 사용하는 방법

php中世界最好的语言
php中世界最好的语言원래의
2018-04-17 14:23:1314153검색

이번에는 Vue에서 계산된 속성을 사용하는 방법을 보여드리겠습니다. Vue에서 계산된 속성을 사용할 때 주의사항은 무엇인가요?

Vue의 계산 속성을 계산 속성이라고 합니다. . 이 섹션에서는 Vue?에서 계산된 속성을 사용하는 방법을 알아봅니다. Vue의 템플릿 관련 지식을 배울 때 템플릿에서 expressions를 사용할 수 있고 템플릿의 표현식이 매우 편리하다는 것을 알았지만 이러한 종류의 순회에는 실제로 일부 간단한 작업에 사용되는 특정 제한이 있습니다. . 즉, 템플릿에 너무 많은 논리를 넣으면 템플릿이 과중해지고 유지 관리가 어려워질 수 있습니다. 먼저 예를 살펴보겠습니다.

<p id="app">
  <h1>{{ message.split('').reverse().join('') }}</h1>
</p>

이 예에서는 템플릿이 더 이상 단순하고 명확하지 않습니다. 여기에 변수 메시지를 표시하려는 반전된 string이 있다는 것을 깨닫기 위해 잠시 지켜봐야 합니다. 여기에서 뒤집힌 문자열을 템플릿에서 여러 번 참조하려는 경우 처리하기가 더 어려워집니다.

이것이 복잡한 논리의 경우 계산된 속성을 사용해야 하는 이유입니다. 다음으로 Vue의 계산 속성에 대해 알아 보겠습니다.

계산된 속성을 사용하면 뷰에 표시된 속성을 빠르게 계산할 수 있습니다. 이러한 계산은 필요한 경우에만 캐시되고 업데이트됩니다.

Vue에서 뷰 값을 설정하는 방법에는 여러 가지가 있습니다:

  • 지시어를 사용하여 데이터 값을 뷰에 직접 바인딩

  • 간단한 표현식을 사용하여 콘텐츠에 대한 간단한 변환 수행

  • filters사용

    filters

    을 사용하여 콘텐츠에 대한 간단한 변환 수행

이 외에도 계산된 속성을 사용하여 데이터 모델의 값 또는 값 집합을 기반으로 표시 값을 계산할 수도 있습니다.

계산된 속성

계산된 속성을 사용하면 지정된 뷰에서 복잡한 값 계산을 수행할 수 있습니다. 이러한 값은 종속성 값에 바인딩되며 필요할 때만 업데이트됩니다.

예를 들어, 데이터 모델에 결과 배열이 있을 수 있습니다:

data () {
  return {
    results: [
      {
        name: 'English',
        marks: 70
      },
      {
        name: 'Math',
        marks: 80
      },
      {
        name: 'History',
        marks: 90
      }
    ]
  }
}
    모든 주제의 총 개수를 보고 싶다고 가정해 보겠습니다. 이 작업을 수행하기 위해 필터나 표현식을 사용할 수 없습니다.
  • 필터: 애플리케이션의 여러 위치에서 필요한 간단한 데이터 형식의 경우
  • 표현식: 스트림 작업이나 기타 복잡한 논리의 사용을 허용하지 않습니다. 간단하게 유지해야 합니다

이때 계산된 속성이 유용할 수 있습니다. 다음과 같이 계산된 값을 모델에 추가할 수 있습니다.

computed: {
  totalMarks: function () {
    let total = 0
    let me = this
    for (let i = 0; i < me.results.length; i++) {
      total += parseInt(me.results[i].marks)
    }
    return total
  }
}

totalMarks 계산 속성은 배열 결과의 마크를 사용하여 총 값을 계산합니다. 단지 값을 반복하여 소계를 반환합니다.

그런 다음 계산된 값을 뷰에 표시할 수 있습니다.

<p id="app">
  <p v-for="subject in results">
    <input v-model="subject.marks">
    <span>Marks for {{ subject.name }}: {{ subject.marks }}</span>
  </p>
  <p>
    Total marks are: {{ totalMarks }}
  </p>
</p>

계산된 속성과 메서드

Vue의 메소드를 사용하여 해당 과목의 총점을 계산할 수 있으며 최종 총점은 동일합니다.

위의 예를 기반으로 계산된 블록의 totalMarks 함수를 메소드로 이동합니다. 또한 템플릿에서 {{ totalMarks }}를 {{ totalMarks() }}로 바꾸세요. 결국 아래와 같이 동일한 결과가 표시됩니다.

let app = new Vue({
 el: '#app',
 data () {
  return {
   results: [
    {
     name: '英语',
     marks: 70
    },
    {
     name: '数学',
     marks: 80
    },
    {
     name: '历史',
     marks: 90
    }
   ]
  }
 },
 methods: {
  totalMarks: function () {
   let total = 0
   let me = this
   for (let i = 0; i < me.results.length; i++) {
    total += parseInt(me.results[i].marks)
   }
   return total
  }
 }
})

이 두 가지 방법의 출력 결과는 동일하지만 성능에는 엄청난 타격을 입게 됩니다. 이 접근 방식을 사용하면 페이지가 렌더링될 때마다(예: 모든 변경 시) totalMarks() 메서드가 한 번 실행됩니다.

계산된 속성이 있는 경우 Vue는 계산된 속성이 의존하는 값(우리의 경우 결과)을 기억합니다. ). 이렇게 하면 Vue는 종속성이 변경될 때만 값을 계산할 수 있습니다. 그렇지 않으면 이전에 캐시된 값이 반환됩니다. 이는 또한 결과가 변경되지 않는 한 여러 번의 방문이 가능함을 의미합니다. totalMarks 계산 속성은 함수를 다시 실행할 필요 없이 이전 계산 결과를 즉시 반환합니다.

위의 두 예는 또한 Vue에서 계산된 속성이 종속성에 따라 캐시되지만 메서드는 종속성에 따라 캐시되지 않는다는 것을 보여줍니다. 따라서 계산된 속성을 사용하면 메서드보다 성능이 더 좋습니다.

🎜 이는 또한 Date.now()가 반응적 종속성이 아니기 때문에 다음 계산 속성이 더 이상 업데이트되지 않음을 의미합니다. 🎜
computed: {
  now: function () {
    return Date.now()
  }
}

相比之下,每当触发重新渲染时,方法的调用方式将总是再次执行函数。因此,函数必须是一个纯函数。它不能有副作用。输出只能依赖于传递给函数的值。

那么我们为什么需要缓存?假设我们有一个性能开销比较大的的计算属性 A ,它需要遍历一个极大的数组和做大量的计算。然后我们可能有其他的计算属性依赖于 A 。如果没有缓存,我们将不可避免的多次执行 A 的 getter !如果你不希望有缓存,请用方法来替代。

计算属性的 setter

计算属性默认只有 getter ,不过在需要时你也可以提供一个 setter :

computed: {
  fullName: {
    // getter
    get: function () {
      return this.firstName + ' ' + this.lastName
    },
    // setter
    set: function (newValue) {
      var names = newValue.split(' ')
      this.firstName = names[0]
      this.lastName = names[names.length - 1]
    }
  }
}

你在输入框中输入一个 fullName ,然后点击 set 按钮,可以看到对应的效果。你现在再运行 app.fullName="Airen liao" 时,计算属性的 setter 会被调用, app.firstName 和 app.lastName 也相应地会被更新。

观察者

虽然计算属性在大多数情况下更合适,但有时候也需要一个自定义的 watcher 。这是为什么Vue通过 watch 选项提供一个更通用的方法,来响应数据的变化。当你想要在数据变化响应时,执行异步操作或开销较大的操作,这是很有用的。

Vue确实提供了一种更通用的方式来观察和响应Vue实例上的数据变动: watch 属性 。当你有一些数据需要随着其它数据变动而变动时,你很容易滥用 watch 。然而,通常更好的想法是使用计算属性而不是命令式的 watch 回调。比如下面的示例:

<p id="app">
  {{ fullName }}
</p>
let app = new Vue({
  el: '#app',
  data () {
    return {
      firstName: 'Foo',
      lastName: 'Bar',
      fullName: 'Foo Bar'
    }
  },
  watch: {
    firstName: function (val) {
      this.fullName = val + ' ' + this.lastName
    },
    lastName: function (val) {
      this.fullName = this.firstName + ' ' + val
    }
  }
})

上面代码是命令式的和重复的。将它与计算属性的版本进行比较:

let app = new Vue({
  el: '#app',
  data () {
    return {
      firstName: 'Foo',
      lastName: 'Bar'
    }
  },
  computed: {
    fullName: function () {
      return this.firstName + ' ' + this.lastName
    }
  }
})

在Vue中使用异步计算属性

Vue中的计算属性非常好。它们允许你执行复杂的操作或数据格式,同时最大限度地执行依赖项计算的性能,只在依赖更改时更新视图。但遗憾的是,它们完全是同步的。

值得庆幸的是,有一个插件。使用vue-async-computed 包可以通地将一个 promise 的值绑定到组件属性来创建和使用组件中的异步计算属性。

我们可以在项目的根目录下通过 yarn 或 npm 来安装 vue-async-computed 插件:

# Yarn
$ yarn add vue-async-computed
# NPM
$ npm i vue-async-computed --save

接下来在你的项目中开启这个插件:

// main.js
import Vue from 'vue';
import AsyncComputed from 'vue-async-computed'
import App from 'App.vue';
Vue.use(AsyncComputed);
new Vue({
  el: '#app',
  render: h => h(App)
});

如果你和我一样,对Vue的构建工具不是很熟悉的话,我建议你使用Vue官方提供的构建工具 Vue CLI 。默认情况,它提供了五种模板,你可以根据自己喜欢的方式选择自己需要的模板即可。

确认在项目中引用 vue-async-computed 之后,咱们就可以开始使用这个插件了。使用如何使用这个插件之前,先来简单的了解一些概念。

在Vue中标准计算属性和异步属性之间有一些区别:

  • 异步属性不能有 setter

  • 直到 promise 的 resolve 为止,除非 default 被设置,否则该值为 null

在大多数情况下,你可以将它们视为返回 promise 的计算属性。

<!-- MyComponent.vue -->
<template>
  <!-- 在一两秒后 myResolvedValue将变成"*Fancy* Resolved Value" -->
  <h2>Asynchronous Property {{ myResolvedValue }}</h2>
</template>
<script>
  export default {
    asyncComputed: {
      myResolvedValue () {
        return new Promise((resolve, reject) => {
          setTimeout(() => resolve('*Fancy* Resolved Value!'), 1000)
        })
      }
    }
  }
</script>

使用ES7 / ES2016的 async / await ,这将变得更简单:

<!-- MyComponent.vue -->
<template>
  <!-- 在一两秒后 myResolvedValue将变成"*Fancy* Resolved Value" -->
  <h2>Asynchronous Property {{ myResolvedValue }}</h2>
</template>
<script>
  function fancinessComesLater () {
    return new Promise((resolve, reject) => {
      setTimeout(() => resolve('*Fancy* Resolved Value!'), 1000)
    })
  }
  export default {
    asyncComputed: {
      async myResolvedValue() {
        return await fancinessComesLater()
      }
    }
  }
</script>

有关于vue-async-computed 更详细的使用和介绍,可以阅读其 官网 提供的相关介绍。

总结

今天主要学习了Vue中的计算属性。在Vue中的计算属性可以让我们很好的监听多个数据或者一个数据来维护返回一个状态值,只要其中一个或多个数据发生变化,则会重新计算整个函数体,重新皇家马德里回状态值,从而更新对应的视图(View)。其次,计算属性具有缓存,相比Vue中的方法而言,性能更佳。但Vue中的计算属性都是同步的,如果需要异步我们得依赖于vue-async-computed 。

저는 Vue의 초보자이기 때문에 Vue의 계산 속성에 대한 이해는 피상적일 뿐입니다. 더 깊은 수준에서 보면 여전히 특정 문제가 있을 것입니다. 여러분이 저를 수정하거나 자신의 경험을 제공할 수 있기를 바랍니다. ​ ​

이 기사의 사례를 읽으신 후 방법을 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!

추천 자료:

기본 Ajax get 및 post 메서드 사용에 대한 자세한 설명

Node.js는 MySQL에 대량의 데이터를 주입합니다

requireJS를 사용하여 맨 위로 돌아가기 기능 추가

위 내용은 Vue에서 계산된 속성을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.