鸿蒙开发:this的指向问题

前言

"你开发的组件,明明我数据改变了,为什么却没有变化?"

"不对吧,你这个封装的不行,我在@Builder函数中获取外部的属性,总是为undefined?"

可以说,以上的反馈,无论是在工作之中,还是在外部的开源中,遇到了无数次,我的回答就一句话,那是你的this指向不对。

this,浅显易懂,就是指的自己,用于类中访问属性和方法,举一个很常见的一个案例,也是最简单的,通常我们给组件设置数据时,经常会用到this,如下所示,this就是指的当前组件Index。

TypeScript 复制代码
@Entry
@Component
struct Index {
  @State title: string = "标题"

  build() {
    Column() {
      Text(this.title)
    }
  }
}

如果是正常的组件引用,一般this不会出现大的问题,但是在自定义组件,用到了@BuilderParam装饰器,在需要外部传递@Builder函数的时候,问题就暴露出来了,我们还是来一个案例。

首先自定义一个组件,如下所示,接收一个外部传递组件layout。

TypeScript 复制代码
@Component
export struct Child {
  title: string = "我是Child"
  @BuilderParam layout: () => void

  build() {
    this.layout()
  }
}

我们把上述的自定义组件Child引用一下,然后自定义一个@Builder函数。

TypeScript 复制代码
@Entry
@Component
struct Index {
 title: string = "我是Index"

  build() {
    Child({
      layout: this.TextView
    })
  }

  @Builder
  TextView() {
    Column() {
      Text(this.title)
    }
  }
}

那么以上的案例,在运行之后,Text组件会显示 "我是Index" 还是 "我是 Child " 呢?

答案是 "我是Child"。


很多同学也会很懵,明明我在Index里调用的this,为什么不是显示Index里的 "我是Index" 数据呢?,哎,这就是this指向问题,也是很多同学在@Builder函数中一直困惑的问题。

this指向分析

以上的案例中,我们在使用自定义组件的时候,是直接通过this传递的,此时的this指向的是自定义组件Child,所以,在@Builder装饰器函数中,this获取的是自定义组件Child里的数据,如果自定义组件中未有定义,那么就为undefined,这也是前言中很多同学的反馈。

TypeScript 复制代码
Child({
      layout: this.TextView
    })

那么如何把this指向,修改宿主对象呢?也就是调用自定义组件的Index组件呢?很简单,只需要,修改为箭头函数即可。

TypeScript 复制代码
Child({
      layout: ()=>{
        this.TextView()
      }
    })

以上的案例,this指向的就是宿主对象,这样就解决了数据为什么为undefined,数据为什么无法更新的问题。

相关总结

所以,在以后遇到@Builder函数的时候,如果你要用到外部宿主的this,书写方式为箭头函数()=>{},在大括号里引用你定义的@Builder函数,切记,箭头函数的this才是指向的是宿主对象,否则指向的是自定义组件。

TypeScript 复制代码
()=>{
  //你定义的@Builder函数
}

所以啊,老铁们,你们在使用别人自定义的组件时,一定要注意到这个this指向问题,并不是别人封装的不对,而是我们使用的方式不对。

希望这个this,能打开你的新世界大门!

相关推荐
2501_9159214310 小时前
如何在苹果手机上面进行抓包?iOS代理抓包,数据流抓包
android·ios·智能手机·小程序·uni-app·iphone·webview
Boyang_11 小时前
在 iOS 26 上@property 的一个小 bug
ios
_李小白11 小时前
【Android 美颜相机】第五天:GPUImageFilterTools
android·数码相机
冬奇Lab11 小时前
【Kotlin系列05】集合框架:从Java的冗长到函数式编程的优雅
android·kotlin·编程语言
奋斗的小青年!!11 小时前
Flutter开发OpenHarmony打卡进度环组件:实现与跨平台兼容性实践
flutter·harmonyos·鸿蒙
冬奇Lab11 小时前
稳定性性能系列之十四——电量与网络优化:Battery Historian与弱网处理实战
android·性能优化·debug
Coffeeee11 小时前
了解一下Android16更新事项,拿捏下一波适配
android·前端·google
用户416596736935511 小时前
深入解析安卓 ELF 16KB 页对齐:原生编译与脚本修复的权衡
android
七牛云行业应用11 小时前
iOS 19.3 突发崩溃!Gemini 3 导致 JSON 解析失败的紧急修复
人工智能·ios·swift·json解析·大模型应用
奋斗的小青年!!11 小时前
Flutter跨平台开发鸿蒙应用:表情选择器组件的深度实践
flutter·harmonyos·鸿蒙