当前位置: 首页 > news >正文

vue中v-bind控制class和style

当使用v-bind指令控制class和style时,可以通过动态绑定的方式根据不同的条件来添加或移除class,以及改变元素的样式。

1. 控制class

通过v-bind:class可以动态绑定class属性。可以使用对象语法、数组语法或者计算属性来实现。

  • 对象语法:使用对象语法,可以根据条件来动态添加或移除class。

    <div :class="{ active: isActive }"></div>
    

    在上面的例子中,如果isActive为true,则会给该元素添加一个名为"active"的class。

  • 数组语法:使用数组语法,可以根据条件来添加或移除多个class。

    <div :class="[isActive ? 'active' : '', isHighlighted ? 'highlighted' : '']"></div>
    

    在上面的例子中,如果isActive为true,则会给该元素添加一个名为"active"的class;如果isHighlighted为true,则会给该元素添加一个名为"highlighted"的class。

  • 计算属性:使用计算属性,可以根据条件来动态计算class。

    <div :class="computedClasses"></div>
    

    computed: {computedClasses() {return {active: this.isActive,highlighted: this.isHighlighted}}
    }
    

    在上面的例子中,根据isActive和isHighlighted的值,计算出一个包含active和highlighted的class对象。

2. 控制style

通过v-bind:style可以动态绑定style属性。可以直接绑定一个样式对象,也可以使用计算属性来计算一个样式对象。

  • 直接绑定样式对象:直接绑定一个样式对象,可以根据条件来动态设置元素的样式。

    <div :style="{ color: isActive ? 'red' : 'blue', fontSize: isHighlighted ? '20px' : '14px' }"></div>
    

    在上面的例子中,如果isActive为true,则设置该元素的color为红色;如果isHighlighted为true,则设置该元素的fontSize为20px。

  • 计算属性:使用计算属性,可以根据条件来计算一个样式对象。

    <div :style="computedStyles"></div>
    

    computed: {computedStyles() {return {color: this.isActive ? 'red' : 'blue',fontSize: this.isHighlighted ? '20px' : '14px'}}
    }
    

    在上面的例子中,根据isActive和isHighlighted的值,计算出一个包含color和fontSize的样式对象。

通过动态绑定class和style,可以根据不同的条件来改变元素的外观和样式,实现更灵活的界面效果。

导航栏选中字体高亮显示

注意以下代码需要放HTML代码中运行

<div id="app"><nav><ul><li v-for="(item, index) in navItems" :key="index" :class="{ active: selectedIndex === index }" @click="selectNavItem(index)" >{{ item.text }}</li></ul></nav></div><script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script>var app = new Vue({el: '#app',data: {navItems: [{ text: '首页', color: '#f44336' },{ text: '关于', color: '#9c27b0' },{ text: '联系', color: '#4caf50' },{ text: '帮助', color: '#ff9800' }],selectedIndex: 0},methods: {selectNavItem(index) {this.selectedIndex = index;}}})

以上代码是一个简单的导航栏组件,使用Vue.js来实现导航栏的点击高亮效果。

在代码中,<div id="app">是Vue实例的挂载点,Vue会将组件渲染到这个挂载点下。

<nav>标签内部是一个无序列表<ul>,通过v-for指令遍历navItems数组,生成列表项<li>v-for="(item, index) in navItems"表示将navItems数组中的每一项item遍历,并将当前项的索引index也绑定到变量中。

:key="index"指定每一个列表项的唯一key值,以便在重绘时进行优化。

:class="{ active: selectedIndex === index }"使用了动态绑定class的对象语法,根据selectedIndex的值和列表项的索引index是否相等,决定是否给该列表项添加名为"active"的class。如果相等,则添加,实现高亮效果。

@click="selectNavItem(index)"绑定了点击事件,当点击列表项时,触发selectNavItem方法,将当前项的索引index传入,从而更新selectedIndex的值,实现切换高亮的效果。

在Vue实例中,data属性中navItems是一个包含导航项的数组,selectedIndex是当前选中的导航项的索引。methods属性中定义了一个selectNavItem方法,用于更新selectedIndex的值。

最后,通过实例化Vue对象,将el属性指定为"#app",将Vue实例挂载到页面上。然后Vue会监听数据的变化,根据数据的变化自动更新界面,实现导航栏的点击高亮效果。

相关文章:

vue中v-bind控制class和style

当使用v-bind指令控制class和style时&#xff0c;可以通过动态绑定的方式根据不同的条件来添加或移除class&#xff0c;以及改变元素的样式。 1. 控制class 通过v-bind:class可以动态绑定class属性。可以使用对象语法、数组语法或者计算属性来实现。 对象语法&#xff1a;使用…...

【面试经典150题】【双指针】392. 判断子序列

题目链接 https://leetcode.cn/problems/is-subsequence/?envTypestudy-plan-v2&envIdtop-interview-150 题解思路 首先如果s的长度大于t的长度&#xff0c;那么s肯定不是t的子序列如果s的长度等于t的长度&#xff0c;那么st的情况下s才是t的子序列如果s的长度小于t的长…...

禁用PS/Photoshop等一系列Adobe旗下软件联网外传用户数据操作

方案一&#xff1a; 下载火绒杀毒&#xff0c;在联网请求上禁用Adobe软件的联网请求&#xff0c;甚至还可以额外发现哪些是它要想要偷偷摸摸干的。 方案二&#xff1a; 最后注意&#xff1a; 用盗版软件只是获得了使用权&#xff01;...

C语言猜输赢游戏

目录 开头游戏的程序游戏的流程图结尾 开头 大家好&#xff0c;我叫这是我58&#xff0c;现在&#xff0c;请你看一下下面的游戏程序。 游戏的程序 #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <Windows.h> int main() {int i 1;int ia 0…...

Rust 异步 trait 的实现困难

在 Rust 中&#xff0c;异步编程是使用 async/await 语法来实现的。与传统的同步编程不同&#xff0c;异步编程涉及到的特性较多&#xff0c;其中一个重要的特性是异步 trait。 异步 trait 是具有异步方法的 trait。在 Rust 中&#xff0c;trait 方法默认是同步的&#xff0c;…...

腾讯云和windows11安装frp,实现内网穿透

一、内网穿透目的 实现公网上&#xff0c;访问到windows上启动的web服务 二、内网穿透的环境准备 公网服务器、windows11的电脑、frp软件(需要准备两个软件&#xff0c;一个是安装到公网服务器上的&#xff0c;一个是安装到windows上的) frp下载地址下载版本 1.此版本(老版…...

Solidity智能合约事件(event)

文章目录 Solidity智能合约事件(event)什么是event事件event有什么作用日志内容位于区块链的什么地方&#xff1f;【重要】以太坊交易获取如何在 Solidity 中使用事件&#xff1f;参考 Solidity智能合约事件(event) 什么是event EVM有一个日志功能&#xff0c;用于将数据“写…...

第2章 Rust初体验7/8:错误处理时不关心具体错误类型的下划线:提高代码可读性:猜骰子冷热游戏

讲动人的故事,写懂人的代码 2.6.6 用as进行类型转换:显式而简洁的语法 贾克强:“大家在查看Rust代码时,可能会注意到这一句。在这里,如果我们不使用as i32,编译器会报错,因为它在u32中找不到abs()方法。这是因为prev和sum_of_two_dice都是u32类型,u32类型并不支持abs(…...

大话C语言:第24篇 预处理

1 C语言编译流程 C语言的编译流程包括&#xff1a; 预编译&#xff1a;将.c 中的头文件展开、宏展开&#xff0c;生成的文件是.i 文件。gcc指令&#xff1a;gcc -E file.c -o file.i 编译&#xff1a;将预处理之后的.i 文件生成 .s 汇编文件。gcc指令&#xff1a;gcc -S file…...

React如何配置路由

ReactTs配置路由 安装依赖 npm i react-router-dom在routers下面创建index.tsx import { RouteObject } from react-router-dom import React from react import PageA from /views/PageA import PageB from /views/PageB const routes: RouteObject[] [{path: /,element: …...

MAC使用初体验+入门

之前从来没有使用过MAC&#xff0c;这次拿到了一个 不得不说MAC度过适应期后用起来很舒服&#xff0c;续航长&#xff0c;触控板舒服&#xff0c;轻薄无比 我前期过度的时候记录的一部分快速指南&#xff0c;掌握如下一些电脑常识 可以做到正常使用了 基本操作 在 Mac 上使用桌…...

Go TOKEN机制与跨域处理方式

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…...

JavaScript 的运行

语法分析预编译解释执行 1.语法分析 语法分析是 JavaScript 引擎处理代码的第一步。 在这个阶段&#xff0c;引擎将源代码字符串分解成一个个的词素&#xff08;token&#xff09;&#xff0c;这些词素是语言中有意义的最小单元&#xff0c;如关键字、变量名、操作符等。 语…...

园区地图导航系统:技术原理、部署方案与智能化应用解析

随着智能化时代的到来&#xff0c;园区管理面临诸多挑战。维小帮园区地图导航系统&#xff0c;采用前沿技术&#xff0c;为园区提供全面的导航解决方案&#xff0c;极大提升了园区管理效率和用户体验。 一、园区地图导航系统的功能特点 维小帮园区地图导航系统&#xff0c;以其…...

【数据结构】第十六弹---C语言实现希尔排序

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】 目录 1、希尔排序( 缩小增量排序 ) 1.1、预排序实现 1.2、希尔排序代码实现 1.3、代码测试 1.4、时空复杂度分析 1.5、性能比较 总结 上一弹我们…...

用Python向Word文档添加页眉和页脚

用Python向Word文档添加页眉和页脚 添加页眉和页脚效果代码 添加页眉和页脚 在本文中&#xff0c;我们将用python向文档中添加页眉和页脚。 效果 添加前的文档&#xff1a; 添加页眉和页脚后&#xff1a; 代码 from docx import Documentdef add_header_footer(doc_path…...

REST风格

黑马程序员Spring Boot2 文章目录 1、REST简介1.1 优点1.2 REST风格简介1.3 注意事项 2、RESTful入门案例 1、REST简介 1.1 优点 隐藏资源的访问行为&#xff0c;无法通过地址的值对资源适合中操作书写简化 1.2 REST风格简介 按照RST风格访问资源时使用行为动作区分对资源进…...

Mongodb连接测试程序【Java版】

先导入Maven依赖 <dependency><groupId>org.mongodb</groupId><artifactId>mongodb-driver-sync</artifactId><version>4.9.0</version> </dependency>import com.mongodb.MongoClientSettings; import com.mongodb.MongoCred…...

SM3国密算法:优秀的密码散列函数

随着信息技术的飞速发展&#xff0c;信息安全已成为全球关注的焦点。密码学作为保障信息安全的核心技术&#xff0c;其重要性不言而喻。中国在密码学领域也取得了显著的成就&#xff0c;其中SM3国密算法就是中国自主设计并推广使用的密码学标准之一。 一、SM3算法概述 SM3算法…...

【安卓】在安卓中使用HTTP协议的最佳实践

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…...

TI INA333数据手册没细说的5个细节:增益电阻怎么选?温漂怎么算?你的电路可能一直没优化

INA333电路设计进阶指南&#xff1a;数据手册没告诉你的5个关键优化点 在精密测量电路设计中&#xff0c;INA333作为TI经典的仪表放大器&#xff0c;被广泛应用于传感器信号调理、医疗设备和工业控制等领域。虽然数据手册提供了基本参数和典型应用电路&#xff0c;但许多工程师…...

基于Azure AI Search与OpenAI构建企业级智能问答系统实战指南

1. 项目概述&#xff1a;当企业级搜索遇上生成式AI 如果你正在为如何让公司内部的知识库、产品文档或客服系统变得更“聪明”而头疼&#xff0c;那么你很可能已经听说过或将接触到这个项目&#xff1a; Azure-Samples/azure-search-openai-demo 。这不仅仅是一个简单的代码示…...

Degrees of Lewdity汉化版全攻略:从入门到精通的四象限实战指南

Degrees of Lewdity汉化版全攻略&#xff1a;从入门到精通的四象限实战指南 价值定位&#xff1a;为什么选择模组化汉化方案&#xff1f; 你是否曾因语言障碍与心仪的开源游戏失之交臂&#xff1f;Degrees of Lewdity作为一款备受欢迎的开源游戏&#xff0c;其丰富的剧情和自…...

(B站TinyML教程学习笔记)C8 edge impulse 快速入门+C9 数据提取+C10 运动数据的特征提取

0:06 - 1:00 为什么使用 Edge Impulse 常见机器学习开发方式 传统机器学习通常会使用&#xff1a; TensorFlowScikit-learn 这些框架功能强大&#xff0c;但&#xff1a; 学习成本高需要写大量代码对嵌入式开发者不太友好 Edge Impulse 的作用 Edge Impulse 核心特点&am…...

Pinecone示例库实战指南:从向量数据库原理到RAG应用开发

1. 项目概述&#xff1a;Pinecone示例库的深度探索 如果你正在寻找一个能让你快速上手向量数据库和现代AI应用开发的“实战训练营”&#xff0c;那么Pinecone官方的 pinecone-io/examples 仓库绝对是一个不容错过的宝藏。这个仓库远不止是一个简单的代码合集&#xff0c;它更…...

AI00 RWKV Server:基于Vulkan的轻量级大模型本地推理部署指南

1. 项目概述&#xff1a;一个为RWKV模型打造的轻量级、高性能推理服务器 如果你正在寻找一个能让你在个人电脑上&#xff0c;甚至是集成显卡上&#xff0c;就能流畅运行大语言模型&#xff08;LLM&#xff09;的解决方案&#xff0c;那么AI00 RWKV Server绝对值得你花时间深入…...

【Midjourney Tempera风格终极指南】:20年AI绘画专家亲授3大参数黄金配比与5类易踩翻车点

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Tempera风格的本质解构与历史溯源 Tempera&#xff08;蛋彩画&#xff09;作为一种古老而精密的绘画媒介&#xff0c;其技术逻辑与现代前端渲染范式存在深层隐喻关联——尤其在“分层合成”“介质绑定”…...

数据可视化项目架构全解析:从核心原理到React+ECharts工程实践

1. 项目概述&#xff1a;数据可视化的价值与“SKY-lv/data-visualization”的定位在数据驱动的时代&#xff0c;我们每天都被海量的信息包围。无论是业务报表、用户行为日志&#xff0c;还是传感器采集的时序数据&#xff0c;它们本身只是一堆冰冷的数字。如何让这些数据“开口…...

Apple Watch深度体验:从传感器融合到物联网节点的技术实践

1. 从怀疑到依赖&#xff1a;一个技术编辑的Apple Watch真实体验说实话&#xff0c;一开始我压根没打算写这篇关于Apple Watch的东西。作为一名在技术媒体圈混了十多年的老编辑&#xff0c;我太清楚这里面的“坑”了——只要你写点苹果产品的好话&#xff0c;就容易被贴上“果粉…...

小米Agent岗二面:你们 RAG 知识库上线之后,文档更新了怎么办?

&#x1f454;面试官&#xff1a;你们 RAG 知识库上线之后&#xff0c;文档更新了怎么办&#xff1f;总不能每次改个文档就把整个知识库重建一遍吧。 &#x1f64b;‍♂️我&#xff1a;可以直接找到变了的那个 chunk&#xff0c;更新它的向量就行了。 &#x1f454;面试官&a…...