0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Vue.jsを1から学んでみた〜フィルター〜

Last updated at Posted at 2020-08-06

Vue.js を1から学んでみた。にて書いてきましたが、
長くなり編集しにくくなってきたので、分割しました(こんなやりかたしないのかな?知りたい。)

9-1. 概要

Utilityクラスの様なもの。
例えば、引数の値を全て大文字にしたいような機能が欲しい場合、定義して使うことができる。

9-2. 基本

利用できるのは、mustache展開({{}} の展開)と v-bindの2つ。

単一指定

対象のVueインスタンスプロパティに対して| (パイプ)を設定する。

sample.html
<!-- mustaches -->
{{ message | capitalize }}

<!-- v-bind -->
<div v-bind:id="rawId | formatId"></div>

複数指定

複数指定する場合は、以下の様に|でつなげる。

sample.html
<!-- mustaches -->
{{ message | capitalize | subString }}

ローカル登録

filtersで登録する。

App.vue
<template>
  <div>
    <Job message="system engineer"></Job>
    <Job message="hogehoge"></Job>
  </div>
</template>

<script>
import Job from "./components/Job.vue";

export default {
  components: {
    Job: Job
  }
}
</script>
Job.vue
<template>
  <div>
    {{ msg | capitalize }}
  </div>
</template>

<script>
export default {
  props: {
    message: {
      type: String
    },
  },
  data: function() {
    return {
      msg: this.message
    }
  },
  // ローカル登録
  filters: {
    capitalize: function (value) {
      if (!value) return ''
      value = value.toString()
      return value.charAt(0).toUpperCase() + value.slice(1)
    }
  }
}
</script>

結果:先頭の文字列だけが大文字
image.png

グルーバル登録

main.jsにて登録する。

main.js
import Vue from 'vue'
import App from './App.vue'

Vue.config.productionTip = false

// グローバル登録
Vue.filter('capitalize', function (value) {
  if (!value) return ''
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
})

new Vue({
  render: h => h(App),
}).$mount('#app')
App.vue
<template>
  <div>
    <Job message="system engineer"></Job>
    <Job message="hogehoge"></Job>
  </div>
</template>

<script>
import Job from "./components/Job.vue";

export default {
  components: {
    Job: Job
  }
}
</script>
Job.vue
<template>
  <div>
    {{ msg | capitalize }}
  </div>
</template>

<script>
export default {
  props: {
    message: {
      type: String
    },
  },
  data: function() {
    return {
      msg: this.message
    }
  },
}
</script>

結果:先頭の文字列だけが大文字
image.png

9-3. 注意事項

  • this.は使えない

computedとの違い

  • computedは、キャッシュが残るため仮想DOMが変更した場合のみ実行される。パフォーマンスの面で優れている。
  • フィルターは、都度実行されるためパフォーマンスの面では劣る。ただ、作りやすく利用もしやすい。
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?