Vue (4)

news2024/11/29 10:38:17

文章目录

  • 1. 绑定样式
    • 1.1 绑定 class 样式
    • 1.2 绑定 style 样式
  • 2. 条件渲染
    • 2.1 v-show
    • 2.2 v-if
  • 3. 列表渲染
    • 3.1 v-for
    • 3.2 key 的作用与原理
    • 3.3 列表过滤
    • 3.4 列表排序

1. 绑定样式


说 绑定样式 前,先准备好 以下几个 样式 :

 <style>
        .basic {
            width: 400px;
            height: 100px;
            border: 1px solid black;
        }

        /* happy , sad , normal 三选一 */

        .happy {
            渐变 : 
            background-image: linear-gradient(180deg, rgb(247, 132, 132), rgb(241, 241, 80));
        }

        .sad {
            背景
            background-color: gray;
            
            边框
            border: 3px dashed green;
        }

        .normal {
            背景颜色
            background-color: skyblue;
        }

        .test1 {
            背景颜色
            background-color: rgb(140, 244, 195);
        }

        .test2 {
           字体大小
            font-size: 50px;
            字体阴影
            text-shadow: 2px 2px 5px red;
        }

        .test3 {
            圆角边框
            border-radius: 20px;
            background-color: yellow
        }
    </style>


关于这些样式,可以在 :CSS 教程 (w3school.com.cn) 上学习到 .

1.1 绑定 class 样式


下面就 开始 学习 vue 中的绑定样式

在这里插入图片描述


注意 当前 相当于 在操作字符串 , 这种绑定class 样式 适用于样式的类名 不确定 ,需要动态指定 .


下面升级一下 : changeMood 方法 , 让他 支持随机切换样式 , 即 当前 a 的值 可以是 happy , 也可以是 sad , 还可以是 normal (注意 :是其中的一个).


做法 很简单 : 写一个数组 存放 happy ,sad , normal , 然后借助随机数 通过这个随机数 ,就可以指定 下标 , 然后通过下标 返回值即可 .


关于 random 不多说 ,不清楚可以看 : JavaScript 随机 (w3school.com.cn)


代码如下 : 效果 , 可以自己尝试实现以下 ,然后观察 .

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>绑定样式</title>
    <script src="../../js/vue.js"></script>
    <style>
        .basic {
            width: 400px;
            height: 100px;
            border: 1px solid black;
        }

        /* happy , sad , normal 三选一 */

        .happy {
            background-image: linear-gradient(180deg, rgb(247, 132, 132), rgb(241, 241, 80));
        }

        .sad {
            background-color: gray;
            border: 3px dashed green;
        }

        .normal {
            background-color: skyblue;
        }

        .test1 {
            background-color: rgb(140, 244, 195);
        }

        .test2 {
            font-size: 50px;
            text-shadow: 2px 2px 5px red;
        }

        .test3 {
            border-radius: 20px;
            background-color: yellow
        }
    </style>

</head>

<body>
    <div id="root">
        <div class='basic' :class="a" @click="changeMood">{{name}}</div>
    </div>

    <script>
        new Vue({
            el: "#root",
            data: {
                name: "迪迦",
                a: "normal"
            },
            methods: {
                changeMood() {

                    let arr = ['happy', 'sad', 'normal']

                    let index = Math.floor(Math.random() * 3)

                    this.a = arr[index]
                }
            }
        })
    </script>

</body>

</html>


绑定 class 样式 数组写法 , 适用场景 要绑定的样式不确定 , 需要动态指定

在这里插入图片描述


绑定class 样式 ,对象写法, 适用于 : 绑定的样式个数确定 , 名字也确定,但要动态决定用不用

在这里插入图片描述


看完 绑定 class , 下面 来看看 如何 绑定 内联的 style .

1.2 绑定 style 样式

在这里插入图片描述


补充一下 : 用的少 , 这里 :style = " " , " " 里面 除了 写 对象,也可以写数组 .

在这里插入图片描述


总结 :

绑定样式 :

  1. class 样式

    a. 写法 : class = “xxx” , xxx 可以是 字符串 ,对象, 数组

    b. 字符串写法 使用与 : 类名不确定 ,要动态获取

    c. 对象写法适用于 : 要绑定多个样式 , 个数不确定 , 名字也不确定

    d. 数组写法适用于: 要绑定多个样式 , 个数确定 , 名字也确定 ,当不确定用不用 .

  2. style 样式

    a. :style="{fontSize : xxx}" 其中 xxx 是动态值

    b. :style = "[a,b]" 其中 a , b 是样式对象

2. 条件渲染


条件渲染 : 顾名思义 ,符合了某些条件,就渲染某些东西

2.1 v-show

在这里插入图片描述

2.2 v-if

在这里插入图片描述


下面就可以通过 v-show 或 v-if 写一个 小交互 :

在这里插入图片描述


下面继续 , 想一想 既然有 v-if ,那么 v-else-if 和 v-else 肯定是少不了的


之前我们如何 使用 if else if , else , 那么 v-if , v-else-if , v-else 就 如何使用 .

在这里插入图片描述


看完了 v-else-if , v-else , 下面来补充一个 标签 template

在这里插入图片描述


总结 :

条件渲染 :

  1. v-if

    写法: 1. v-if = “表达式” , 2. v-else-if = “表达式” , 3. v-else (这里也可以写表达式)

    适用于 : 切换频率较低的场景

    特点 : 不展示的DOM元素直接被移除

    注意 : v-if 可以和 :v-else-if , v-else 一起使用 ,但要求结构不能被 “打断” .

  2. v-show

    写法 : v-show=“表达式”,

    适用于 : 切换频率较高的场景.

    特点 : 不展示的 DOM 元素未被移除 , 仅仅是使用样式隐藏掉

  3. 备注 使用 v- if 的时候,元素可能无法获取到 (v-if=“false” ,当前DOM 元素就被移除了),而使用 v-show 一定可以获取到

3. 列表渲染

3.1 v-for


1. 遍历数组 :

在这里插入图片描述


看完了遍历数组,下面来看看如何使用 v-for 遍历对象


2. 遍历对象

在这里插入图片描述


除了 数组 , 对象 , v-for 还能遍历字符串 ,用的不多 ,了解即可

3. 遍历字符串

在这里插入图片描述


最后来看一个 比 遍历字符串 用的还少的 ,指定遍历的次数


4. 指定遍历次数

在这里插入图片描述


总结 :

v-for指令 :

  1. 用于展示列表数据
  2. 语法 : v-for = "(item,index) in xxx" :key = "yyy"
  3. 可遍历 : 数组 , 对象 , 字符串 (用的很少) , 指定次数 (用的很少) .

3.2 key 的作用与原理


上面说 v-for 中的 key 是让 每个 li 拥有 唯一的 id , 这里就来细说一下 ,key 的作用 和 原理


图一 :

在这里插入图片描述


图二 :

在这里插入图片描述


这里补充一下 : 如果 写 v-for 遍历 列表的时候 ,没有写 key vue 会做一个默认的动作 ,会将遍历时的索引值(下标) 自动作为key ,这也是为啥之前没写 key 也出错的原因.


总结

面试题 : react , vue 中的 key 有什么作用 ? (key 的 内部原理)

  1. 虚拟 DOM 中的key 的作用 :

    a. key 是 虚拟 DOM 对象的标识 , 当状态中的数据发生变化时 , Vue 会根据 新数据 生成 新的虚拟DOM 随后 Vue 进行 新虚拟 DOM 旧 虚拟 DOM 的差异比较 。 比较规则如下 :

  2. 对比规则 :

    a. 旧虚拟 DOM 中找到了 与 新虚拟 DOM 相同的 key :

    • 若旧 虚拟 DOM 中内容没变 , 直接使用之前的 真实 DOM !
    • 若虚拟 DOM 中内容变了 , 则生成新的真实 DOM ,随后 替换掉页面中之间的真实 DOM 。

    b. 旧虚拟 DOM中未找到 与 新虚拟 DOM 相同的key

    • 创建新的 真实 DOM , 随后渲染到页面上
  3. 用 index 作为 key 可能会引发的问题 :

    a. 若 对数据进行 : 逆序添加,逆序删除等破坏顺序操作 : 会产生没必要的真实 DOM 根性 --> 界面效果没问题 ,但效率低.

    b. 如果结构中还包含 输入类的 DOM : 会产生 错误 DOM 更新 —> 界面有问题

  4. 开发中如何选着 key ?

    a.最好使用每条数据的唯一标识 作为 key , 比如 id , 手机号 , 身份证 , 学号等 唯一值.

    b.如果不存在对数据的逆序添加 , 逆序删除等破坏顺序操作 ,仅 用于渲染列表用于展示,使用index作为 key 是没问题的。

3.3 列表过滤


通过 : 实现 一段代码 来学习 列表过滤

效果 :

在这里插入图片描述


补充 : JavaScript Array filter() 方法 (w3school.com.cn)


图一 :

在这里插入图片描述


图二 :

在这里插入图片描述


用 watch 实现 , 下面来看看 用computed 如何实现

在这里插入图片描述

3.4 列表排序


这里 对 刚刚的列表过滤 升级以下,添加一个排序功能 .


实现效果 :

在这里插入图片描述


实现 :

在这里插入图片描述


sort 方法 : JavaScript Array sort() 方法 (w3school.com.cn)

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

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

相关文章

四数之和(详细题解:双指针+排序)

18. 四数之和 难度中等1502 给你一个由 n 个整数组成的数组 nums &#xff0c;和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] &#xff08;若两个四元组元素一一对应&#xff0c;则认为两个四元组重复&#x…

Java 魔法类 Unsafe 详解

阅读过 JUC 源码的同学&#xff0c;一定会发现很多并发工具类都调用了一个叫做 Unsafe的类。 那这个类主要是用来干什么的呢&#xff1f;有什么使用场景呢&#xff1f;这篇文章就带你搞清楚&#xff01; Unsafe 介绍 Unsafe 是位于 sun.misc 包下的一个类&#xff0c;主要提…

要发计算机SCI论文,参考文献应该怎么引用? - 易智编译EaseEditing

SCI论文发表中经常被引用的参考文献主要有以下四种。 一是关于具体的实验的方法&#xff0c;二是支持性或者有冲突的证据&#xff0c;三是比较有用的类似的文献&#xff0c;四是有历史背景的和有意义的文献。 其实归根到底&#xff0c;你引用的SCI的参考文献必须对你的论文发表…

031_SSS_Imagic Text-Based Real Image Editing with Diffusion Models

Imagic: Text-Based Real Image Editing with Diffusion Models 1. Introduction 本文提出了一种新的基于Diffusion的方法称作Imagic&#xff0c;可以实现复杂的基于文本的图像编辑。与之前的方法不同&#xff0c;本文的方法只需要一张输入图像和一个目标文本&#xff0c;并且…

线程私有变量ThreadLocal详解

本文已收录至Github&#xff0c;推荐阅读 &#x1f449; Java随想录 烈火试真金&#xff0c;逆境试强者。——塞内加 文章目录什么是ThreadLocalThreadLocal 原理set()方法get()方法remove()方法ThreadLocal 的Hash算法ThreadLocal 1.7和1.8的区别ThreadLocal 的问题ThreadLoca…

StarRocks获评「2022 中国开源社区健康案例」!

近日&#xff0c;OSCHINA 2022年度中国开源项目评选结果正式揭晓&#xff0c;StarRocks开源社区成功入选 OSCHINA “2022中国开源社区健康案例”&#xff01;开源社区健康指的是围绕一个开源项目形成的社区中关于项目的技术迭代、社区的组织架构、成员构成、开源治理、上下游协…

【手写 Vuex 源码】第十二篇 - Vuex 插件机制的实现

一&#xff0c;前言 上一篇&#xff0c;主要介绍了 Vuex 插件的开发&#xff0c;主要涉及以下几个点&#xff1a; Vuex 插件的使用介绍&#xff1b;Vuex 插件开发和使用分析&#xff1b;Vuex 插件机制的分析&#xff1b; 本篇&#xff0c;继续介绍 Vuex 插件机制的实现&…

moveToCoordinateF3DconcatenateRotations

moveToCoordinate 演示视频: 注意:前提是3~6轴机器人机构且不是PickAndPlace 该方法_3D。Poses.moveToCoordinate 移动由 指定的对象,该对象 对应于支持的机器人配置之一,只要标识的机器人配置支持,其第一个动画指向指定坐标和指定旋转。这无需您定义姿势即可工作。 工…

Python期末复习知识点大合集(期末不挂科版)

Python期末复习知识点大合集&#xff08;期末不挂科版&#xff09; 文章目录Python期末复习知识点大合集&#xff08;期末不挂科版&#xff09;一、输入及类型转换二、格式化输出&#xff1a;字符串的format方法三、流程控制四、随机数生成五、字符串六、序列索&#xff08;含字…

stm32f407探索者开发板(十五)——NVIC中断优先级管理

文章目录零、前言一、NVIC中断优先级分组1.1 中断的管理方法1.2 抢占优先级&相应优先级的区别1.3 举例1.4 特别说明1.5 中断优先级分组函数二、NVIC中断优先级设置2.1 中断设置相关寄存器2.2 中断设置优先级2.2.1 中断优先级控制的寄存器组 IP[240]2.2.2 中断使能寄存器组 …

TCP核心机制之连接管理详解(三次握手,四次挥手)

目录 前言&#xff1a; 建立连接 建立连接主要两个TCP状态&#xff1a; 断开连接 断开连接的两个重要状态 小结&#xff1a; 前言&#xff1a; TCP是如何建立对端连接&#xff0c;如何断开连接&#xff0c;这篇文章会详细介绍。 建立连接 首先明确连接的概念&#xff1a…

Docker系列之九巧用Nginx

前言 Nginx是个很棒的反向代理服务工具&#xff0c;之前我都是直接安装到服务器上去&#xff0c;过程繁琐也许不是难以接受&#xff0c;但是有更简单地Docker镜像服务&#xff0c;我自然没必要再次舍近求远。 一些配置是参考自我以前的文章Docker系列一安装Docker和Hexo历险记…

影片自由,丝滑流畅,Docker容器基于WebDav协议通过Alist挂载(百度网盘/阿里云盘)Python3.10接入

使用过NAS(Network Attached Storage)的朋友都知道&#xff0c;它可以通过局域网将本地硬盘转换为局域网内的“网盘”&#xff0c;简单理解就是搭建自己的“私有云”&#xff0c;但是硬件和网络成本都太高了&#xff0c;有点可望而不可及的意思。Alist开源库则可以满足我们&…

Docker+Nginx+KeepaLived实现Nginx一主一从高可用

系统版本 Centos7 IP&#xff1a;10.10.11.79 Master IP&#xff1a;10.10.11.81 Slave 虚拟ip&#xff1a;10.10.11.77 客户端发起一个请求 &#xff0c;请求没有到Nginx的实际IP上&#xff0c;而是请求的虚拟IP(会和实际IP通过配置文件进行绑定&#xff09; 如果有一台Nginx…

Linux进阶(Shell编程学习一)

由于shell脚本在java项目运维方面极其重要&#xff0c;比如服务的启动脚本&#xff0c;日志的分割脚本&#xff0c;文件的管理脚本大多都是shell脚本去实现的。所以作为java开发者懂linux的基本命令&#xff0c;会基本的shell编程是必要的。 Shell 是一个用 C 语言编写的程序&…

nodejs+vue学生考试成绩数据分析与可视化系统vscode

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.3 B/S结构 4 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;技术背景…

springboot 集成driud

druid官方文档导入jar包<dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>${druid-spring.version}</version></dependency>配置数据源spring:datasource:url: jdbc:m…

什么是销售管理?销售管理的五大职能

销售管理听起来很简单&#xff0c;似乎只是负责销售并确保客户满意&#xff0c;但事实上&#xff0c;它远不止于此。 销售管理的实际职能包括监督销售团队的工作&#xff0c;制定计划和设定目标&#xff0c;通常还包括确保销售流程的效率以获得最佳业务结果。 什么是销售管理…

千兆网口down/up偶发link成百兆问题

a. 软硬件环境&#xff1a;​NXP LS1043A IGB211&#xff08;pcie接口千兆网卡&#xff09;:linux 4.9.19 igb driver Nvidia Xavier NX RTL8211F: linux4.9​ ​NXP LS1043A -----(pcie)--- IGB211 <---(PCB走线代替网线)-----> RTL8211F&#xff08;phy&#xff09;…

剑指 Offer 56 - II. 数组中数字出现的次数 II

题目 在一个数组 nums 中除一个数字只出现一次之外&#xff0c;其他数字都出现了三次。请找出那个只出现一次的数字。 思路 这题是剑指 Offer 56 - I. 数组中数字出现的次数的变体&#xff0c;本题只有一个数num出现一次&#xff0c;其余的均出现三次 三次的话使用异或消无法…