vue与react中监听的简单对比

一、核心概念对比

Vue监听机制

  • 响应式核心‌:基于Object.defineProperty(Vue2)/Proxy(Vue3)的数据劫持

  • 主要API‌:

    • data + watch侦听器
    • computed计算属性
    • $watch方法
  • 设计哲学‌:声明式编程,自动依赖追踪

React监听机制

  • 响应式核心‌:基于不可变数据和虚拟DOM diff

  • 主要API‌:

    • useState + useEffect
    • useMemo/useCallback
    • 类组件的生命周期方法
  • 设计哲学‌:函数式编程,显式控制

二、代码实现对比(含优化方案)

Vue实现示例

javascript 复制代码
export default {
  data() {
    return {
      count: 0,
      user: { 
        name: 'John',
        profile: { age: 30 }
      }
    }
  },
  watch: {
    // 基础监听
    count(newVal, oldVal) {
      console.log(`Count变化: ${oldVal}→${newVal}`);
    },
    // 深度监听优化
    user: {
      handler(val) { /* 处理逻辑 */ },
      deep: true,
      immediate: false  // 避免初始化执行
    },
    // 精确监听嵌套属性
    'user.profile.age': function(newAge) {
      console.log('年龄变化:', newAge);
    }
  },
  computed: {
    // 带缓存的计算属性
    userInfo() {
      return `${this.user.name}-${this.user.profile.age}`;
    }
  }
}

React实现示例

javascript 复制代码
import { useState, useEffect, useMemo, useCallback } from 'react';

function UserComponent() {
  const [count, setCount] = useState(0);
  const [user, setUser] = useState({ 
    name: 'John',
    profile: { age: 30 }
  });

  // 基础监听(类似watch)
  useEffect(() => {
    console.log('count变化:', count);
  }, [count]);  // 明确依赖

  // 深度监听优化方案
  useEffect(() => {
    console.log('user变化:', user);
  }, [user.name, user.profile.age]);  // 精确指定依赖

  // 计算属性优化(类似computed)
  const userInfo = useMemo(() => {
    return `${user.name}-${user.profile.age}`;
  }, [user.name, user.profile.age]);

  // 事件处理优化
  const handleClick = useCallback(() => {
    setCount(prev => prev + 1);
  }, []);

  return (
    <div>
      <p>{userInfo}</p>
      <button onClick={handleClick}>增加</button>
    </div>
  );
}

三、深度对比分析

1. 响应式原理差异

维度 Vue React
数据跟踪 自动依赖收集 手动声明依赖
更新触发 精确到属性级别 组件级别重新渲染
实现方式 编译时转换+运行时劫持 运行时虚拟DOM diff

2. 性能优化对比

优化策略 Vue实现方式 React实现方式
计算缓存 自动缓存的computed 需手动useMemo
函数缓存 方法自动绑定 需手动useCallback
列表渲染 v-for自带key优化 需手动指定key
深度监听 内置deep:true支持 需手动拆解对象属性

3. 开发体验对比

开发场景 Vue优势 React优势
快速原型 更少的样板代码 更灵活的组件组合
复杂状态 自动化的响应式更新 更精确的状态控制
跨平台 更好的uni-app整合 更丰富的React Native生态
TypeScript 需要额外类型定义 一流的TS支持

四、Uniapp开发中的监听实践

1. Vue语法下的特殊处理

javascript 复制代码
// 在uni-app中需要特别注意的watch用法
export default {
  watch: {
    // 监听全局变量变化
    '$store.state.token'(newVal) {
      uni.setStorageSync('token', newVal);
    },
    // 处理平台差异
    someValue: {
      handler(val) {
        // #ifdef H5
        console.log('H5特有处理');
        // #endif
      }
    }
  }
}

2. React语法下的注意事项

scss 复制代码
function UniAppComponent() {
  const [sysInfo, setSysInfo] = useState({});
  
  useEffect(() => {
    // 获取系统信息
    uni.getSystemInfo({
      success: res => setSysInfo(res)
    });
  }, []);

  // 处理平台特定逻辑
  useEffect(() => {
    // #ifdef MP-WEIXIN
    console.log('微信小程序特有逻辑');
    // #endif
  }, [sysInfo]);
}
相关推荐
小码哥_常35 分钟前
安卓黑科技:实现多平台商品详情页一键跳转APP
前端
killerbasd38 分钟前
还是迷茫 5.3
前端·react.js·前端框架
不会敲代码11 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
kyriewen2 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·github·openai
AC赳赳老秦2 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
kyriewen2 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
前端·javascript·设计模式
不会敲代码12 小时前
从零搭建 AI 日记助手:用 Milvus 向量数据库实现语义搜索
javascript·openai
千寻girling2 小时前
《 Git 详细教程 》
前端·后端·面试
threelab3 小时前
Three.js UV 图像变换效果 | 三维可视化 / AI 提示词
javascript·人工智能·uv
之歆4 小时前
DAY08_CSS浮动与行内块布局实战指南(下)
前端·css