Vue3源码解读:内置代理

除了用户可以使用reactive、shallowReactive、readonly、shallowReadonly创建代理外,Vue3内部也创建了若干代理。

一  渲染代理

创建组件实例时,会创建组件的渲染代理。

function setupStatefulComponent(instance,isSSR) {
  // ...
  
  instance.proxy = markRaw( // 标记为不可代理
    new Proxy(instance.ctx, PublicInstanceProxyHandlers) // 创建代理
  ) 

  // ...
}

二 输入属性代理

浏览器端渲染类组件时,会创建输入属性代理。

if (isStateful) {
  instance.props = isSSR ? props : shallowReactive(props) 
}

三 透传属性代理

创建setup函数的上下文时,会创建透传属性代理。

export function createSetupContext(instance){
  // ...
  return {
    get attrs() {
      return attrs || (attrs = createAttrsProxy(instance))
    },
    slots: instance.slots,
    emit: instance.emit,
    expose
  }
}

四 暴露代理

子组件若有expose,父组件中访问子组件时使用的是暴露代理。

export function setRef(rawRef, oldRawRef, parentSuspense, vnode, isUnmount) {
  // ...
  const refValue =
    vnode.shapeFlag & ShapeFlags.STATEFUL_COMPONENT
      ? getExposeProxy(vnode.component) || vnode.component.proxy
      : vnode.el;
  // ...
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,让我来回答你的问题。 首先,我们需要了解一下 `Object.defineProperty` 这个方法。它是一个 JavaScript 的内置方法,用于在一个对象上定义一个新的属性或者修改一个已有的属性。这个方法接受三个参数,分别是要定义属性的对象、属性名和属性描述符。 其中,属性描述符是一个包含了四个属性的对象:`value`、`writable`、`enumerable` 和 `configurable`。`value` 属性指定了属性的值,`writable` 属性指定了属性是否可写,`enumerable` 属性指定了属性是否可枚举,`configurable` 属性指定了属性是否可配置。 在 Vue 组件中,我们可以使用 `Object.defineProperty` 来定义响应式数据。具体来说,我们可以在组件的 `data` 选项中定义一个对象,并使用 `Object.defineProperty` 将该对象的属性转换成响应式数据,这样当我们修改属性时,组件会自动重新渲染。 下面是一个简单的例子,展示了如何使用 `Object.defineProperty` 定义一个响应式数据: ``` const obj = {} Object.defineProperty(obj, 'name', { value: 'Vue', writable: true, enumerable: true, configurable: true }) ``` 这里我们定义了一个空对象 `obj`,然后使用 `Object.defineProperty` 将该对象的属性 `name` 定义为一个响应式数据,初始值为 `'Vue'`。由于 `writable` 属性被设置为 `true`,所以我们可以修改 `obj.name` 的值,而这个修改会触发组件的重新渲染。 希望我的回答能够解决你的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值