实际开发中 | 与 || 的使用方法及组件封装方案解析

一、基本使用方法

  1. 按位或运算符(|) 常用于二进制位操作,如权限控制、状态合并等场景。
javascript 复制代码
// 权限控制示例
const READ = 1;    // 二进制: 0001
const WRITE = 2;   // 二进制: 0010
const DELETE = 4;  // 二进制: 0100

// 组合权限
let userPermission = READ | WRITE; // 0011 = 3

// 检查权限
if (userPermission & READ) {
  console.log("用户拥有读取权限");
}
  1. 逻辑或运算符(||) 常用于条件判断中的短路求值,或设置默认值。
javascript 复制代码
// 短路求值示例
function validateInput(value) {
  if (!value || value.length === 0) {
    return "输入不能为空";
  }
  return "验证通过";
}

// 默认值设置
const config = {
  timeout: options.timeout || 3000,
  retries: options.retries || 3
};

二、组件封装方案

  1. 位操作工具类封装
javascript 复制代码
class BitwiseUtils {
  constructor() {}

  // 合并多个标志位
  static combineFlags(...flags) {
    return flags.reduce((result, flag) => result | flag, 0);
  }

  // 检查是否包含某个标志位
  static hasFlag(value, flag) {
    return (value & flag) === flag;
  }

  // 移除某个标志位
  static removeFlag(value, flag) {
    return value & ~flag;
  }
}

// 使用示例
const permissions = BitwiseUtils.combineFlags(READ, WRITE);
BitwiseUtils.hasFlag(permissions, DELETE); // false
  1. 逻辑判断组件封装(React示例)
javascript 复制代码
function ConditionalComponent({ condition, left, right }) {
  return condition ? left : right;
}

// 使用示例
<ConditionalComponent 
  condition={user.isAdmin || user.hasPermission("edit")}
  left={<AdminPanel />}
  right={<UserPanel />}
/>

三、进阶应用场景

  1. 性能优化:短路求值的应用
javascript 复制代码
// 避免不必要的函数调用
function expensiveOperation() {
  console.log("执行耗时操作");
  return true;
}

// 当isEnabled为false时,不会执行expensiveOperation
if (isEnabled || expensiveOperation()) {
  // 处理逻辑
}
  1. 二进制状态机
javascript 复制代码
class StateMachine {
  constructor() {
    this.state = 0;
  }

  // 设置状态
  setState(state) {
    this.state |= state;
  }

  // 清除状态
  clearState(state) {
    this.state &= ~state;
  }

  // 检查状态
  isActive(state) {
    return (this.state & state) !== 0;
  }
}

// 使用示例
const machine = new StateMachine();
machine.setState(LOADING);
machine.isActive(LOADING); // true

四、注意事项

  1. 运算符优先级问题
javascript 复制代码
// 错误示例:可能导致逻辑错误
if (a || b & c) { ... }

// 正确示例:使用括号明确优先级
if (a || (b & c)) { ... }
  1. 类型转换陷阱
javascript 复制代码
// 非布尔值在逻辑运算中的转换
0 || 5; // 返回5(真值)
'' || 'default'; // 返回'default'

通过合理封装和使用这两个运算符,可以提高代码的可读性和可维护性,同时避免潜在的逻辑错误。在实际开发中,建议根据具体场景选择合适的运算符,并通过工具类或组件化的方式将通用逻辑封装复用。


JavaScript, 前端开发,逻辑运算符,位运算符,组件封装,组件化开发,前端



准备了一些面试资料,请在以下链接中获取 pan.quark.cn/s/4459235fe...


相关推荐
Hilaku2 分钟前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试
非凡ghost4 分钟前
AIMP(音乐播放软件)
前端·windows·音视频·firefox
xiaotao1316 分钟前
Vite 完全学习指南
前端·vite·前端打包
军军君0120 分钟前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
IT枫斗者27 分钟前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
hotlinhao28 分钟前
Nginx rewrite last 与 redirect 的区别——Vue history 模式短链接踩坑记录
前端·vue.js·nginx
ZC跨境爬虫31 分钟前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
下北沢美食家34 分钟前
CSS面试题2
前端·css
weixin_4617694041 分钟前
npm create vue@latest 错误
前端·vue.js·npm
WindrunnerMax42 分钟前
从零实现富文本编辑器#13-React非编辑节点的内容渲染
前端·架构·github