1
2

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 1 year has passed since last update.

vue-simple-suggestで読み仮名でもサジェストさせる

Posted at

背景・課題

  • 漢字でリスト表示していても、ひらがな入力時点でサジェストさせたい
  • 漢字に変換するまでサジェストがされないのが不便すぎる

vue-simple-suggestのサジェストをカスタマイズする

使っていたのは、vue-simple-suggestでした。既にスタイルが当たっていたのでどうにかしてこれを使いたかったです。
https://github.com/KazanExpress/vue-simple-suggest

結論としては、display-attributeと、filterを指定すれば実装できました。
(ドキュメントに書いてあるけど、filterの指定はわからなさすぎてソースコード読みました :tea:
display-attributeで、どのkeyの値をサジェストのリストに表示するかを指定できます。
filterは入力された値に対してリストの値をどう返すか処理が書けます。

以下は、listDataが[{ name: "hogehoge", kana: "ほげほげ"}]みたいな配列になっている前提でのサンプルコードです。(nuxt.js)

<vue-simple-suggest
    :value="value"
    display-attribute="name"
    :list="listData"
    :filter="vueSimpleSuggestfilter"
    :filter-by-query="true"
    :max-suggestions="100"
/>
 data () {
    return {
      listData: [{ name: "hogehoge", kana: "ほげほげ"}]
    }
  },
  methods: {
    vueSimpleSuggestfilter (el, value) {
      return el.name.indexOf(value) !== -1 || el.kana.indexOf(value) !== -1 ? el : false
    },

ellistで指定した値が一つずつ入ってきて、valueに入力値が入ってきます。
returnした値がサジェストのリストとして表示されます。
拡張したら、カタカナとかアルファベットも追加できますね :ok_hand:

1
2
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
1
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?