vue使用computed實現動態過濾


效果:

 


 

 <div id="test">
        Filter:<input type="text" v-model="searchlanguage" />

       <ul>
            <li v-for="language in searchResults">
                {{language}}
            </li>
        </ul>
    </div>
HTML Source Code

 

  new Vue({
            el: '#test',
            data() {
                return{
                    searchlanguage: '',
                    devlanguages: [
                        'angularjs',
                        'vue.js',
                        'asp.net',
                        'asp.net mvc',
                        'mysql',
                        'ms sql server',
                        'python',
                        '.net core'
                    ]
                }
            },
            computed: {
                searchResults() {
                    let filter = new RegExp(this.searchlanguage, 'i')
                    return this.devlanguages.filter(el => el.match(filter))
                }
            }
        })
JavaScript Source Code

 

computed是計算屬性,是基於它們的響應式依賴進行緩存的。即是說,只有在相關響應式依賴發生改變時它們才會重新求值。

 


免責聲明!

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



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