Flutter .obx 与 Rxn<T>的区别

如何使用 DeepSeek 帮助自己的工作? 10w+人浏览 622人参与

 

1️⃣ .obs

  • Rx 的简写,最常用的写法。

  • 一般用法:


var count = 0.obs; // int 类型的响应式 var name = 'Jack'.obs; // String 类型 var user = UserModel(...).obs; // 非空对象

  • 特点

    1. 变量 不能为 null,必须初始化一个非空值。

    2. .value 用来读写值。

示例:


var user = UserModel(id:1, name:'Jack', email:'a@b.com', username:'jack', avatar:'').obs; // 修改 user.value.name = 'Tom'; user.value = newUser; // 访问 print(user.value.name);

  • 如果你想用 .obs,就必须给 user 一个初始值,哪怕是空对象(UserModel(id:0, name:'',...))。


2️⃣ Rxn<T>

  • Rxn = Rx nullable,可为空的响应式变量

  • 适合 初始值为空,后续可能赋值或者清空(未登录状态)


var user = Rxn<UserModel>(); // 初始值为 null // 登录后赋值 user.value = UserModel(id:1, name:'Jack', email:'a@b.com', username:'jack', avatar:''); // 退出登录时清空 user.value = null; // UI 使用 Obx 自动刷新 Obx(() { if (user.value == null) { return Text('未登录'); } else { return Text('欢迎, ${user.value!.name}'); } });

  • 特点

    1. 可以为空,不需要一开始就初始化。

    2. .value 访问方式和 .obs 一样。

    3. 非常适合“用户信息”这种未登录时为空、登录后赋值的场景。


3️⃣ 总结对比表

特性.obsRxn<T>
是否允许 null❌ 不允许✅ 可以为空
是否必须初始化✅ 必须❌ 可以不初始化
使用方式var x = value.obs; x.valuevar x = Rxn<T>(); x.value
场景示例计数器、非空对象用户信息、可选对象

💡 小结

  • 你的里用户信息用 Rxn<UserModel> 更合适,因为用户可能 未登录,user = null

  • .obs 适合 一开始就有初始值 的变量,比如计数器、状态标志等。

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <plist version="1.0"> <dict> <key>NSAppTransportSecurity</key> <dict> <key>NSAllowsArbitraryLoads</key> <true/> </dict> <key>CFBundleDevelopmentRegion</key> <string>$(DEVELOPMENT_LANGUAGE)</string> <key>CFBundleDisplayName</key> <string>Newdemo</string> <key>CFBundleExecutable</key> <string>$(EXECUTABLE_NAME)</string> <key>CFBundleIdentifier</key> <string>$(PRODUCT_BUNDLE_IDENTIFIER)</string> <key>CFBundleInfoDictionaryVersion</key> <string>6.0</string> <key>CFBundleName</key> <string>newdemo</string> <key>CFBundlePackageType</key> <string>APPL</string> <key>CFBundleShortVersionString</key> <string>$(FLUTTER_BUILD_NAME)</string> <key>CFBundleSignature</key> <string>????</string> <key>CFBundleVersion</key> <string>$(FLUTTER_BUILD_NUMBER)</string> <key>LSRequiresIPhoneOS</key> <true/> <key>UILaunchStoryboardName</key> <string>LaunchScreen</string> <key>UIMainStoryboardFile</key> <string>Main</string> <key>UISupportedInterfaceOrientations</key> <array> <string>UIInterfaceOrientationPortrait</string> <string>UIInterfaceOrientationLandscapeLeft</string> <string>UIInterfaceOrientationLandscapeRight</string> </array> <key>UISupportedInterfaceOrientations~ipad</key> <array> <string>UIInterfaceOrientationPortrait</string> <string>UIInterfaceOrientationPortraitUpsideDown</string> <string>UIInterfaceOrientationLandscapeLeft</string> <string>UIInterfaceOrientationLandscapeRight</string> </array> <key>UIViewControllerBasedStatusBarAppearance</key> <false/> <key>CADisableMinimumFrameDurationOnPhone</key> <true/> <key>UIApplicationSupportsIndirectInputEvents</key> <true/> </dict> </plist> 这个配置有没有错误或者遗漏的地方
11-17
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值