Vue输入框模糊搜索的多种写法

(1)模板方案

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>
<body>
    <!-- 输入框模糊搜索 -->
    <div id="box">
        <input type="text" v-model="mytext"/>
        <ul>
            <template v-for="item in dataList" :key="item">
                <li v-if="item.includes(mytext)">{{ item }}</li>
            </template>
        </ul>
    </div>
    <script>
        var obj = {
            data(){
                return {
                    mytext:'',
                    dataList:['aaa','abc','acb','add','abb','acc','bca','cca','bba','ccc','bbb'],
                }
            }
        }
        Vue.createApp(obj).mount('#box')
    </script>
</body>
</html>

(2)复制方案 (浪费内存不优雅)

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>
<body>
    <!-- 输入框模糊搜索 -->
    <div id="box">
        <input type="text" v-model="mytext"/ @input="handleInput">
        <ul>
            <template v-for="item in dataList" :key="item">
                <!-- <li v-if="item.includes(mytext)">{{ item }}</li> -->
                 <li>{{item}}</li>
            </template>
        </ul>
    </div>
    <script>
        var obj = {
            data(){
                return {
                    mytext:'',
                    dataList:['aaa','abc','acb','add','abb','acc','bca','cca','bba','ccc','bbb'],
                    baklist:['aaa','abc','acb','add','abb','acc','bca','cca','bba','ccc','bbb'] // 复制data
                }
            },
            methods:{
                handleInput(){
                  this.dataList = this.baklist.filter(item=>item.includes(this.mytext))
                }
            }
        }
        Vue.createApp(obj).mount('#box')
    </script>
</body>
</html>

(3)函数表达式

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>
<body>
    <!-- 输入框模糊搜索 -->
    <div id="box">
        <input type="text" v-model="mytext"/>
        <ul>
            <template v-for="item in test()" :key="item">
                <li>{{ item }}</li>
            </template>
        </ul>
    </div>
    <script>
        var obj = {
            data(){
                return {
                    mytext:'',
                    dataList:['aaa1','abc','acb','add','abb','acc','bca','cca','bba','ccc','bbb','aac','aab'],
                }
            },
            methods:{
                test(){
                    return this.dataList.filter(item=>item.includes(this.mytext))
                }
            }
        }
        Vue.createApp(obj).mount('#box')
    </script>
</body>
</html>

(4)watch监听

(5)计算属性

相关推荐
测试员周周5 分钟前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
西洼工作室1 小时前
前端直传OSS服务端签名(Policy+Signature)/STS临时凭证
前端·文件上传·oss
你很易烊千玺2 小时前
日常练习-数组 字符串常用的场景
前端·javascript·字符串·数组
weixin199701080162 小时前
[特殊字符] RESTful API 接口规范详解:构建高效、可扩展的 Web 服务(附 Python 源码)
前端·python·restful
存在的五月雨3 小时前
Vue3项目一些语法
前端·javascript·react.js
nashane3 小时前
HarmonyOS 6学习:Web组件同层渲染事件处理与智能长截图实现
前端·学习·harmonyos·harmonyos 5
大家的林语冰3 小时前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js
三*一3 小时前
Mapbox GL JS 自研面要素整形工具开发实录
开发语言·javascript·arcgis·ecmascript
nashane3 小时前
HarmonyOS 6学习:Web组件同层渲染触摸事件与长截图拼接实战
前端·学习·harmonyos·harmonyos 5