在 Vue.js 开发中,位运算(Bitwise Operations)是一种高效的工具,尤其适用于需要管理大量布尔状态或优化性能的场景。位运算通过操作二进制位来实现状态的存储和检查,相比传统的数组或对象操作,内存占用更低,执行速度更快。本篇博客将介绍如何在 Vue.js 中应用位运算技巧,结合 Vue 的响应式系统实现高效的状态管理。读vue3响应式源码有感
https://github.com/vuejs/core/blob/main/packages/reactivity/src/effect.ts

什么是位运算?

位运算是直接操作数字的二进制位,主要包括以下操作符:

  • &(与):两个位都为 1 时结果为 1。
  • |(或):任一位为 1 时结果为 1。
  • ^(异或):两个位不同时结果为 1。
  • ~(非):翻转所有位。
  • <<(左移):位向左移动,低位补 0。
  • >>(右移):位向右移动,高位补符号位。

在 JavaScript 中,位运算操作 32 位整数,适合处理布尔状态集合。

场景 1:权限管理

位运算在权限管理中非常实用。我们可以用一个整数表示多种权限状态,例如“读”、“写”、“删除”等。

示例代码

// 定义权限位
const PERMISSION_READ = 1 << 0;  // 0001
const PERMISSION_WRITE = 1 << 1; // 0010
const PERMISSION_DELETE = 1 << 2; // 0100
const PERMISSION_EDIT = 1 << 3;  // 1000export default {data() {return {userPermission: 0 // 初始权限状态};},methods: {// 添加权限setPermission(permission) {this.userPermission |= permission;},// 检查权限hasPermission(permission) {return (this.userPermission & permission) === permission;},// 移除权限removePermission(permission) {this.userPermission &= ~permission;}},template: `<div><button @click="setPermission(${PERMISSION_READ} | ${PERMISSION_WRITE})">授予读写权限</button><p>可读: {{ hasPermission(${PERMISSION_READ}) }}</p><p>可写: {{ hasPermission(${PERMISSION_WRITE}) }}</p><button @click="removePermission(${PERMISSION_WRITE})">移除写权限</button></div>`
};

工作原理

  • userPermission 是一个响应式数据,存储所有权限状态。
  • 使用 | 添加权限,& 检查权限,& ~ 移除权限。
  • Vue 的响应式系统会自动追踪 userPermission 的变化,更新视图。

优点

  • 高效:一个整数即可表示 32 种权限,内存占用极低。
  • 响应式:单一变量的变更触发视图更新,符合 Vue 的设计理念。

场景 2:多选状态管理

在处理复选框组时,位运算可以高效管理选中状态,替代数组操作。

示例代码

export default {data() {return {selectedOptions: 0 // 选中状态};},methods: {toggleOption(optionBit) {this.selectedOptions ^= optionBit; // 切换选中状态},isOptionSelected(optionBit) {return (this.selectedOptions & optionBit) !== 0;}},template: `<div><label><input type="checkbox" :checked="isOptionSelected(1)" @change="toggleOption(1)"> 选项 1</label><label><input type="checkbox" :checked="isOptionSelected(2)" @change="toggleOption(2)"> 选项 2</label><label><input type="checkbox" :checked="isOptionSelected(4)" @change="toggleOption(4)"> 选项 3</label></div>`
};

工作原理

  • 每个选项对应一个位(1 << n),selectedOptions 存储所有选中状态。
  • 使用 ^ 切换选中状态,& 检查是否选中。
  • Vue 响应式系统确保 UI 随 selectedOptions 变化而更新。

优点

  • 性能优于数组操作(如 includessplice)。
  • 单一响应式变量减少 Vue 的追踪开销。

场景 3:条件渲染优化

位运算可以简化复杂条件渲染逻辑,例如根据用户状态显示不同 UI。

示例代码

const IS_LOGGED_IN = 1 << 0; // 0001
const IS_VIP = 1 << 1;      // 0010
const IS_ADMIN = 1 << 2;    // 0100export default {data() {return {userState: 0};},computed: {showAdminPanel() {return (this.userState & (${IS_LOGGED_IN} | ${IS_ADMIN})) === (${IS_LOGGED_IN} | ${IS_ADMIN});},showVipContent() {return (this.userState & (${IS_LOGGED_IN} | ${IS_VIP})) === (${IS_LOGGED_IN} | ${IS_VIP});}},methods: {loginAsAdmin() {this.userState |= ${IS_LOGGED_IN} | ${IS_ADMIN};},loginAsVip() {this.userState |= ${IS_LOGGED_IN} | ${IS_VIP};}},template: `<div><button @click="loginAsAdmin">以管理员登录</button><button @click="loginAsVip">以 VIP 登录</button><div v-if="showAdminPanel">管理员面板</div><div v-if="showVipContent">VIP 内容</div></div>`
};

工作原理

  • 使用位运算检查多条件组合(如“已登录且是管理员”)。
  • 计算属性 showAdminPanelshowVipContent 响应式更新 UI。

优点

  • 逻辑清晰,减少 if-else 嵌套。
  • 计算属性与位运算结合,性能和可读性兼得。

注意事项

  1. 响应式系统

    • 确保位运算直接修改响应式数据(如 this.userState |= ...),否则 Vue 无法检测变化。
    • 避免操作非响应式变量。
  2. 位数限制

    • JavaScript 位运算限制在 32 位,适合少于 32 种状态的场景。
    • 更多状态需拆分为多个整数或使用其他数据结构。
  3. 可读性

    • 位运算对新手可能不友好,建议添加注释或封装工具函数。
    • 示例工具函数:
      function debugBits(value) {return (value >>> 0).toString(2).padStart(8, '0');
      }
      
  4. 适用场景

    • 位运算适合简单布尔状态管理,复杂逻辑仍需对象或数组。
    • 权衡性能和代码可维护性。

总结

位运算在 Vue.js 中是一种强大的优化工具,适用于权限管理、多选状态、条件渲染等场景。结合 Vue 的响应式系统,位运算可以在保持高效的同时无缝触发视图更新。然而,由于其可读性较低,建议在性能敏感的场景中使用,并搭配清晰的注释或封装。希望这篇博客能帮助你在 Vue 项目中灵活运用位运算,优化状态管理!

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java SE】Clonable接口和深拷贝

目录 一.Clonable接口 实现步骤&#xff1a; 完整代码&#xff1a; 二.深拷贝 实现步骤&#xff1a; 完整代码&#xff1a; 浅拷贝与深拷贝的对比 使用场景建议 完 浅拷贝&#xff08;Shallow Copy&#xff09;和深拷贝&#xff08;Deep Copy&#xff09;是对象复制的两…

accelerate 在Pycham中执行的设置方法

背景 使用 accelerate 进行分布式代码训练时&#xff0c;需要在pycharm中进行调试&#xff0c;此时需要在pycharm中运行。 终端执行命令 # *[Specify the config file path and the GPU devices to use] export CUDA_VISIBLE_DEVICES0# *[Specify the config file path] expo…

探索量子计算与法律理论的交叉领域

文章目录 前言 一、引言 二、内容 (一)知识产权 (二)隐私与安全 (三)责任认定 (四)证据与证明 (五)法律推理与决策 三、结论 总结 前言 随着量子计算技术的突破性发展,其引发的法律范式重构问题日益凸显。乌兹别克斯坦学者伊索姆别克・阿卜迪哈基莫夫于2024年在《量…

js迭代器

文章目录前言实现原理&#xff1a;调用迭代器自制迭代器前言 迭代器是 JSt 中一种特殊的对象&#xff0c;它提供了一种统一的、通用的方式遍历个各种不同类型的数据结构。 可以遍历的数据结构包括&#xff1a;数组、字符串、Set、Map 等可迭代对象。我们也可以自定义实现迭代器…

chainlink VRF中文教程(含mock),解决error: Arithmetic Underflow in createSubscription

⸻我使用的版本&#xff1a;chainlink-brownie-contracts version:1.3.0⸻1. Import 相关包 ,,, import {VRFConsumerBaseV2Plus} from "chainlink/contracts/src/v0.8/vrf/dev/VRFConsumerBaseV2PLUS.sol"; import {VRFV2PlusClient} from "chainlink/contract…

非线性优化框架CasADi工具箱求解最优控制问题OCP

CasADi是一个开源的Python/MATLAB库&#xff0c;主要用于数值优化&#xff0c;特别是最优控制问题。它提供了一个易于使用的符号框架&#xff0c;用于处理和生成表达式&#xff0c;以及高效地生成导数信息。 https://web.casadi.org/get/https://web.casadi.org/get/ 所有OCP…

Type-C接口台式显示器:LDR6021引领新潮流

Type-C单口便携显示器LDR6021是市场上一种新兴的显示设备&#xff0c;以下是对其的详细介绍一、主要特点 便携性:LDR6021采用了Type-C接口作为数据传输和供电接口&#xff0c;这种设计使得它能够与各种支持Type-C接口的设备无缝连接&#xff0c;如笔记本电脑、智能手机、平板电…

在翻译语义相似度和会议摘要相似度评估任务中 ,分类任务 回归任务 生成任务区别

在翻译语义相似度&#xff08;Translation Semantic Similarity&#xff09;和会议摘要相似度&#xff08;Meeting Summary Similarity&#xff09;等任务中&#xff0c;通常会根据任务的目标和输出形式&#xff0c;将其划分为三类常见的任务类型&#xff1a;1. 分类任务定义&a…

UGUI 性能优化系列:第二篇——Canvas 与 UI 元素管理

UGUI 性能优化系列&#xff1a;第一篇——基础优化与资源管理 UGUI 性能优化系列&#xff1a;第二篇——Canvas 与 UI 元素管理 UGUI 性能优化系列&#xff1a;第三篇——渲染与像素填充率优化 UGUI 性能优化系列&#xff1a;第四篇——高级优化与注意事项 在 UGUI 性能优化…

企业开发转型 | 前端AI化数字化自动化现状

文章目录前端AI化数字化自动化发展现状引言调研背景与目的调研范围与方法前端AI化技术现状与工具生态主流AI工具分类与能力矩阵工具能力对比分析关键能力指标深度解析大模型技术成熟度评估前端AI化核心应用场景与人力优化路径代码生成与自动化开发设计到代码全链路自动化自动化…

Mysql(运维-日志)

黑马mysql笔记 最好开两个窗口&#xff0c;一个用于mysql命令&#xff0c;一个用于liunx命令 目录 错误日志 二进制日志 介绍 日志格式 mysq默认二进制日志文件为ROW 日志查看 二进制日志查看命令 默认日志文件格式下查看日志内容 更改日志文件格式查看日志内容 日志…

RabbitMQ:解锁高效消息传递的密码[特殊字符]

目录 一、RabbitMQ 核心概念 1.1整体框架 1.2元素详解 1.2.1 生产者&#xff08;Producer&#xff09;&消费者&#xff08;Consumer&#xff09; 1.2.2 交换机&#xff08;Exchange&#xff09; ①fanout &#xff08;广播型&#xff09; ②direct &#xff08;直连型…

StarRocks × MinIO:打造灵活高效的存算分离方案

“存算分离”&#xff08;Decoupled Storage and Compute&#xff09;是一种在现代数据系统中被广泛采用的架构设计。它将计算和存储解耦&#xff0c;使二者可以独立扩展&#xff0c;提升资源利用率并降低运维成本。StarRocks 从 3.0 版本开始支持这一架构&#xff0c;允许用户…

R语言的分位数回归实践技术高级应用

回归是科研中最常见的统计学研究方法之一&#xff0c;在研究变量间关系方面有着极其广泛的应用。由于其基本假设的限制&#xff0c;包括线性回归及广义线性回归在内的各种常见的回归方法都有三个重大缺陷&#xff1a;(1)对于异常值非常敏感&#xff0c;极少量的异常值可能导致结…

Tomcat的部署、单体架构、session会话、spring

一、Tomcat的部署①②③④⑤二.web项目在tomcat服务中如何运行&#xff1a;1.web项目源码部署在服务器的webapps目录里面2.将web项目打包(war),部署在服务器的webapps目录里面。三 单体架构和前后端分离单体架构是将所有功能模块&#xff08;包括前端界面、后端逻辑、数据库交互…

海康威视视觉算法岗位30问及详解

海康威视视觉算法岗位30问及详解 前言 视觉算法工程师是人工智能领域的热门岗位&#xff0c;尤其在安防、自动驾驶、工业检测等行业有着广泛应用。海康威视作为行业龙头&#xff0c;对视觉算法岗位的要求较高&#xff0c;面试问题既考察基础理论&#xff0c;也关注工程实现。本…

14.7 Alpaca格式深度解析:3倍指令准确率提升的LLM微调秘诀

文章目录 Alpaca格式深度解析:3倍指令准确率提升的LLM微调秘诀 指令微调格式:Alpaca Format 深度解析 14.3.1 Alpaca 格式诞生背景与技术价值 14.3.2 Alpaca 格式结构解析 14.3.3 实战 Dolly-15K 数据转 Alpaca 格式 14.3.4 Alpaca 格式的工程化实践 14.3.5 格式扩展与挑战应…

42.sentinel实现线程隔离

线程隔离有两种实现方式: 1.线程池隔离 优点: 1.支持主动超时,线程池中的线程都是可控的,可以停掉某个线程。 2.支持异步调用,每个请求都是一个独立的线程,线程之间不受影响。 缺点: 线程的额外开销比较大 适用场景: 低扇出(一个微服务,不会依赖很多微服务)…

【过拟合和欠拟合】——深度学习.全连接神经网络

目录 1 概念认知 1.1 过拟合 1.2 欠拟合 1.3 如何判断 2 解决欠拟合 3 解决过拟合 3.1 L2正则化 3.1.1 数学表示 3.1.2 梯度更新 3.1.3 作用 3.1.4 代码实现 3.2 L1正则化 3.2.1 数学表示 3.2.2 梯度更新 3.2.3 作用 3.2.4 与L2对比 3.2.5 代码实现 3.3 Drop…

Java设计模式之行为型模式(备忘录模式)应用场景分析

最近看到一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站 一、用户交互与编辑操作 文本编辑器撤销/重做 场景描述&#xff1a;用户编辑文档时&#xff0c;可通过CtrlZ撤销误操作&#xff0c;或通过Ctr…