Vue列表过滤与数据原理

news2024/12/23 10:32:51

目录

列表过滤

使用计算属性

 使用watch监视属性

列表排序

Vue中数据原理

练习数据原理

 Vue中数据原理总结


列表过滤

可以进行模糊搜索

使用计算属性

<!DOCTYPE html>
<html lang="en" xmlns:v-model="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--vue-->
    <script src="https://cdn.staticfile.org/vue/2.7.0/vue.min.js"></script>

</head>

<div id="root">
    <input type="text" placeholder="请输入你想搜索的" v-model:value="searchWorld">
<li v-for="p in filterP" :key="p.id">
   {{p.id}}--{{p.name}}--{{p.age}}--{{p.sex}}
</li>
</div>


<script type="text/javascript">
    const vm = new Vue({
        el: '#root',
        data: {
            error:'',
            searchWorld:'',
            persons:[
                {id:1,name:'蒋介石',age:"19岁",sex:'男'},
                {id:2,name:'齐白石',age:"32岁",sex:'男'},
                {id:3,name:'白居易',age:"42岁",sex:'男'},
                {id:4,name:'介居齐',age:"30岁",sex:'女'}
            ],
        },

         computed: {
             immediate: true,
             filterP() {
                 //返回值作为计算属性的值
                 return this.persons.filter((p) => {
                     return p.name.indexOf(this.searchWorld) !== -1
                 })
             }
         }


    });
    console.log(vm)

</script>

<body>

</body>
</html>

运行结果

 使用watch监视属性

<!DOCTYPE html>
<html lang="en" xmlns:v-model="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--vue-->
    <script src="https://cdn.staticfile.org/vue/2.7.0/vue.min.js"></script>

</head>

<div id="root">
    <input type="text" placeholder="请输入你想搜索的" v-model:value="searchWorld"><span style="color: red" >{{error}}</span>
    <span style="color: green" >{{mess}}</span>
<li v-for="p in filterP" :key="p.id">
   {{p.id}}--{{p.name}}--{{p.age}}--{{p.sex}}
</li>
</div>


<script type="text/javascript">
    const vm = new Vue({
        el: '#root',
        data: {
            mess:'',
            error:'',
            searchWorld:'',
            persons:[
                {id:1,name:'蒋介石',age:"19岁",sex:'男'},
                {id:2,name:'齐白石',age:"32岁",sex:'男'},
                {id:3,name:'白居易',age:"42岁",sex:'男'},
                {id:4,name:'介居齐',age:"30岁",sex:'女'}
            ],
            filterP:[],

        },
   
   watch: {
        searchWorld: {

            immediate: true,

          handler(){
           this.error=this.mess='',
           this.filterP =this.persons.filter((p) => {

              return  p.name.indexOf(this.searchWorld)!== -1
              })
              if (this.filterP==''){
                  this.error='找不到'
              }else {
                  this.mess="找到了"
              }

          }
       }
    }

    });
    console.log(vm)

</script>

<body>

</body>
</html>

运行结果

列表排序

<!DOCTYPE html>
<html lang="en" xmlns:v-model="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--vue-->
    <script src="https://cdn.staticfile.org/vue/2.7.0/vue.min.js"></script>

</head>

<div id="root">
    <input type="text" placeholder="请输入你想搜索的" v-model:value="searchWorld">
<button @click="sortNum=1">年龄升序</button>
<button @click="sortNum=2">年龄降序</button>
<button @click="sortNum=0">原顺序</button>
    <li v-for="p in filterP" :key="p.id">
   {{p.id}}--{{p.name}}--{{p.age}}--{{p.sex}}
</li>
    现在是:<span style="color: green">{{sortName}}</span>
</div>


<script type="text/javascript">
    const vm = new Vue({
        el: '#root',
        data: {
            sortName:'原顺序',
             sortNum:0,
            searchWorld:'',
            persons:[
                {id:1,name:'蒋介石',age:19,sex:'男'},
                {id:2,name:'齐白石',age:32,sex:'男'},
                {id:3,name:'白居易',age:43,sex:'男'},
                {id:4,name:'介居齐',age:23,sex:'女'}
            ],

        },

        computed: {
             immediate: true,
             filterP() {
                 //返回值作为计算属性的值,filter为过滤
              const  arrSort=this.persons.filter((p) => {
                     return p.name.indexOf(this.searchWorld) !== -1
                 })
                 this.sortName='原顺序'
                 //判断用户是否需要排序
                    if (this.sortNum!=0){
                 arrSort.sort((big,small)=>{
                   this.sortName= this.sortNum===1?'升序':'降序'
                     return this.sortNum===1?big.age-small.age: small.age-big.age

                 })
                }
                return arrSort
             }

         }



    });
    console.log(vm)

</script>

<body>

</body>
</html>

 arrSort.sort((big,small)=>big-small是升序排序,反之则为降序

运行结果

Vue中数据原理

练习数据原理

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--vue-->
    <script src="https://cdn.staticfile.org/vue/2.7.0/vue.min.js"></script>

</head>

<body >
<div id="root">
    <h2>学生信息</h2>
    学生姓名:{{student.name}}<br>
    学生年龄:{{student.age}}<br/>
    学生性别:{{student.sex}}<br/>
    <h3>学生爱好:</h3>
    <ul>
        <li v-for="(h,index) of student.hobby" :key="index">
            {{h}}
        </li>
    </ul><br/>
    <h3>朋友们:</h3>
    <ul>
        <li v-for="(h,index) of student.friends" :key="index">
            {{h.name}}-{{h.age}}
        </li>
    </ul><br/>

    <button @click="student.age++">点击年龄加1</button>
    <button @click="addSex">添加性别♀女</button>
    <button @click="student.sex='男🚹'">切换为♂男</button>
<button @click.once="addFriend">添加一个🐻的朋友</button><br><br>
<button @click.once="changeFriend">改第一个朋友的名字</button>
    <button @click="addHobby">添加一个游泳🏊爱好</button>
    <button @click="changeHobby">修改第一个爱好为开车🚗</button>
</div>

    <script type="text/javascript">
        const vm = new Vue({
            el: '#root',
            data: {
                student:{
                    name:'小麻瓜🍉',
                    age:19,
                    hobby:['学习📕','吃饭🍚','睡觉😴💤'],
                    friends:[
                        {name:'吧不略',age:20},
                        {name:'皮',age:21}
                    ]
                },
            },
            methods: {
                addSex(){
                    // Vue.set(this.student,'sex','女🚺')
                    vm.$set(this.student,'sex','女🚺')
                },
                addFriend(){
                 this.student.friends.unshift({name:'熊大',age:5})
                },

                changeFriend(){
                    this.student.friends[0].name='熊二'
                },
                addHobby(){
                    this.student.hobby.push('游泳🏊‍')
                },
                changeHobby(){
                    this.student.hobby.splice(0,1,"开车🚆")//从第0个开发,删一个,添加为开车
                }
            }

        });
        console.log(vm)

    </script>
</body>
</html>

 Vue中数据原理总结

1、vue会监视data中所有层次的数据。

2、如何监视对象中的数据?

  • 通过setter实现监视,且要在new Vue时就传入要检测的数据。
  • 对象中后追加的属性,Vue默认不作响应式处理(没有get set作为监视,vue检测不到数据的变化)

如需给后添加的属性做响应式,得使用vue提供的API:

Vue.set(target,propertyName/index,value)vm.$set(target,propertyName/index,value)

  • 第一个参数target是要添加目标位置,如vm._data.student
  • 第二个参数propertyName是要添加的值或者如果前面的是数组,那这个就是索引,
  • 第三个参数value是添加的值

3、如何监视数组中的数据?

通过包裹的数组跟心元素的方法实现,本质就是做了:

  1. 调用原生对应的方法对数组进行更新
  2. 重新解释模版,进而更新页面

4、在Vue修改数组中的某个元素一定要用如下方法:

  • 使用这些API:push()、pop()、shift()、unshift()、splice()、sort()、reverse()
  • Vue.set()或vm.$set()

特点注意:Vue.set()和vm.$set()不能给vm或vm的根数据对象_data添加属性

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/516283.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

YARN框架概述

Yarn 概述 Yarn概述对Yarn的需求简介变迁YARN于MRv1的区别MRv1YARN介绍 YARN集群安装部署集群角色介绍ResourceManager(RM)NodeManager(NM)集群部署规划 YARN RM重启机制概述**开启重启机制**RM状态数据的存储介质开启 后续正在学习&#xff1a;YARN HA高可用 YARN架构体系官方…

DNDC模型

由于全球变暖、大气中温室气体浓度逐年增加等问题的出现&#xff0c;“双碳”行动特别是碳中和已经在世界范围形成广泛影响。国家领导人在多次重要会议上讲到&#xff0c;要把“双碳”纳入经济社会发展和生态文明建设整体布局。同时&#xff0c;提到要把减污降碳协同增效作为促…

harbor(docker仓库)仓库部署

harbor仓库部署 1. harbor概述2. harbor主要功能3. harbor架构介绍4. Docker Compose4.1 compose简介4.2 docker-compose工具命令 5. harbor部署5.1 部署Docker Compose5.2 部署harbor5.3 部署harbor开机自启 6. harbor应用6.1 配置客户端访问harbor6.2 harbor的web管理界面 1.…

炸裂!Hugging Face 发布重磅更新,人手一个 AutoGPT!

公众号关注 “GitHubDaily” 设为 “星标”&#xff0c;每天带你逛 GitHub&#xff01; Hugging Face&#xff0c;作为 AI 开源圈最为知名的「网红」创业公司&#xff0c;成立仅几年&#xff0c;便在 GitHub 开源了诸多实用开源项目&#xff0c;受到了不少开发者的赞赏。 其中影…

中小学智慧校园平台电子班牌系统源码的应用

智慧校园云平台电子班牌系统源码 智慧班牌系统是专门为学校打造的智能信息展示平台&#xff0c;为学校、教师、学生、家长创造一个学习成长交流的共享平台。主要用于显示班级信息、 班级风采、校园文化、课程表、校园活动通知、家校互联等。以图片、音视频、文字、动画、文档等…

【ADS867x】14 位 500kSPS 4/8 通道 ADC 简介及驱动应用示例

器件特性 具有集成模拟前端的 14 位模数转换器 (ADC)具有自动和手动扫描功能的 4 通道、8 通道多路复用器通道独立可编程输入&#xff1a; 10.24V、5.12V、2.56V、1.28V、0.64V10.24V、5.12V、2.56V、1.28V 5V 模拟电源&#xff1a;1.65V 到 5V I/O 电源恒定的阻性输入阻抗&am…

Android 14 快速适配要点

随着 Google I/O 2023 发布的 Android beta2 &#xff0c;预计 Android 14 将在2023年第三季度发布&#xff0c;目前看整体需要适配的内容已经趋向稳定&#xff0c;那就根据官方文档简单做个适配要点总结吧。 如何做到最优雅的版本适配&#xff1f;那就是尽可能提高 minitSdkVe…

详细版易学版TypeScript - 类型声明:字符串数字null布尔undefined数组any对象void类型推断联合类型

根据官方 TypeScript 的注意事项&#xff0c;建议不要使用 Number、String、Boolean、Symbol 或 Object。 ts各类型声明的代码如下&#xff1a; 一、字符串类型 let str: string hello; str ts; 二、数字类型 let num: number 123; num 456; 三、布尔类型 let flag: boolea…

C语言实现队列--数据结构

&#x1f636;‍&#x1f32b;️Take your time ! &#x1f636;‍&#x1f32b;️ &#x1f4a5;个人主页&#xff1a;&#x1f525;&#x1f525;&#x1f525;大魔王&#x1f525;&#x1f525;&#x1f525; &#x1f4a5;代码仓库&#xff1a;&#x1f525;&#x1f525;魔…

No.065<软考>《(高项)备考大全》【专项3】《论文》

《论文》 1 论文部分相关1.1 考试相关1.2 考试核心相关1.3 历年考试分析1.4 复习建议1.5 评分标准1.5.1 评分的几个方面1.5.2 不及格的几种类型1.5.3 扣分项1.5.4 加分项 1.6 时间进度安排1.7 如何准备 2 必背核心知识 - 10大领域47个过程3 论文写作技巧3.1 论文架构3.2 论文题…

SpringBoot——引导类的简单介绍

简单介绍&#xff1a; 之前我们就说到过引导类&#xff0c;之不过当时就是简单的说了一下这个名字&#xff0c;让大家记住我们运行的程序的学名叫做引导类&#xff0c;但是我们并没有进入看过&#xff0c;介绍过它的作用&#xff0c;这次我们就来简单的介绍一下这个类的作用。…

[NLP] SentenceTransformers使用介绍

SentenceTransformers 是一个可以用于句子、文本和图像嵌入的Python库。 可以为 100 多种语言计算文本的嵌入并且可以轻松地将它们用于语义文本相似性、语义搜索和同义词挖掘等常见任务。 该框架基于 PyTorch 和 Transformers&#xff0c;并提供了大量针对各种任务的预训练模型…

STEP7-MicroWin SMART中修改变量注释的具体方法(绝对寻址+符号寻址)

STEP7-MicroWin SMART中修改变量注释的具体方法(绝对寻址+符号寻址) 如下图所示,我们可以在符号表中定义变量的符号名称以及注释信息, 使用时需注意以下事项: 1.在 STEP 7-Micro/WIN SMART 软件中,可以建立多个符号表,但不允许将相同的符号名多次用作全局符号赋值,在单…

1707_Python中的多成员处理

全部学习汇总&#xff1a; GreyZhang/python_basic: My learning notes about python. (github.com) 欢迎路过的YUAN类朋友们&#xff0c;希望我们能够相互交流共同成长。如有错误或者不足希望及时指点指出&#xff0c;不胜感激&#xff01;以下是我的联系方式&#xff1a; E…

Kali-linux识别活跃的主机

尝试渗透测试之前&#xff0c;必须先识别在这个目标网络内活跃的主机。在一个目标网络内&#xff0c;最简单的方法将是执行ping命令。当然&#xff0c;它可能被一个主机拒绝&#xff0c;也可能被接收。本节将介绍使用Nmap工具识别活跃的主机。 网络映射器工具Nmap Nmap是一个…

JavaScript经典教程(七)-- JavaScript中级

197&#xff1a;in、预解析、变量提升、对象引用、Date对象 1、预解析 即&#xff0c;把var的变量在&#xff0c;作用域下&#xff0c;提前&#xff1b; &#xff08;1&#xff09;JS代码运行原理 预先解析&#xff0c;JS第一次解析代码叫预解析。 JS本身会解析两次代码&a…

vue非单文件组件

非单文件组件指的是&#xff1a;一个文件中包含了多个组件。 Vue 中使用组件的三大步骤&#xff1a;1. 创建组件、2. 注册组件、3. 使用组件。 组件使用流程【第一步&#xff1a;创建组件】 利用 Vue.extend() 方法创建组件: // 第一步&#xff1a;创建 frameHead 组件 cons…

前端015_标签模块_删除功能

标签模块_删除功能 1、需求分析2、EasyMock 添加模拟接口3、Api 调用接口4、测试1、需求分析 当点击删除按钮后, 弹出提示框。点击确定后,执行删除并刷新列表数据 确认消息弹框参考:https://element.eleme.cn/#/zh-CN/component/message-box#que-ren-xiao-xi 2、EasyMock …

【AUTOSAR】【以太网】TCPIP

目录 一、概述 二、约束和假设 三、依赖模块 3.1 EthIf 3.2 EthSM 3.3 SoAd 3.4 KeyM 3.5 CSM 四、功能说明 4.1 系统扩展性 4.2 IPv4 4.2.1 IPv4 4.2.2 ARP 4.2.3 Auto-IP 4.2.4 ICMP 4.3 IPv6 4.4 IPSec 4.5 基于IP的协议 4.5.1 本地地址表 4.5.2 UDP 4…

音视频八股文(12)-- ffmpeg 音频重采样

1重采样 1.1 什么是重采样 所谓的重采样&#xff0c;就是改变⾳频的采样率、sample format、声道数等参数&#xff0c;使之按照我们期望的参数输出。 1.2 为什么要重采样 为什么要重采样&#xff1f;当然是原有的⾳频参数不满⾜我们的需求&#xff0c;⽐如在FFmpeg解码⾳频…