当前位置: 首页 > wzjs >正文

网站首页设计原则免费建设网站软件下载

网站首页设计原则,免费建设网站软件下载,建设网站的会计分录,重庆市建设工程一、核心概念 ViewBinding 是 Android Jetpack 组件,用于替代传统 findViewById,提供类型安全和空安全的视图访问方式。它会在编译时为每个 XML 布局文件生成绑定类,直接映射视图 ID。 // 传统方式 vs ViewBinding val textView findViewB…

一、核心概念

ViewBinding 是 Android Jetpack 组件,用于替代传统 findViewById,提供类型安全空安全的视图访问方式。它会在编译时为每个 XML 布局文件生成绑定类,直接映射视图 ID。

// 传统方式 vs ViewBinding
val textView = findViewById<TextView>(R.id.tv_title)  // 传统
binding.tvTitle.text = "Hello ViewBinding"            // ViewBinding

二、ViewBinding优点

  1. 类型安全:自动匹配视图类型,避免类型转换错误

  2. 空安全:生成的视图引用永不为 null(除非布局中不存在)

  3. 编译时检查:XML-ID 错误在编译时暴露,而非运行时崩溃

  4. 代码简洁:消除模板代码,提升可读性

  5. 性能优化:编译时生成代码,零运行时开销

三、使用流程

1. 启用 ViewBinding (模块级 build.gradle)
android {buildFeatures {viewBinding true}
}
2. 自动生成的绑定类

布局文件:activity_main.xml

<LinearLayout><TextView android:id="@+id/tvHeader" /><Button android:id="@+id/btnSubmit" />
</LinearLayout>

将生成绑定类:ActivityMainBinding.java

public final class ActivityMainBinding {public final TextView tvHeader;public final Button btnSubmit;...
}
3. Activity 中使用
class MainActivity : AppCompatActivity() {private lateinit var binding: ActivityMainBindingoverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)binding = ActivityMainBinding.inflate(layoutInflater)setContentView(binding.root)  // 关键:设置根视图// 直接访问视图binding.tvHeader.text = "Welcome"binding.btnSubmit.setOnClickListener {// 处理点击事件}}
}
4. Fragment 中使用
class HomeFragment : Fragment() {private var _binding: FragmentHomeBinding? = nullprivate val binding get() = _binding!! // 安全解包override fun onCreateView(inflater: LayoutInflater,container: ViewGroup?,savedInstanceState: Bundle?): View {_binding = FragmentHomeBinding.inflate(inflater, container, false)return binding.root}override fun onDestroyView() {super.onDestroyView()_binding = null  // 防止内存泄漏}
}
5. 自定义视图组件中使用
class CustomView @JvmOverloads constructor(context: Context,attrs: AttributeSet? = null
) : LinearLayout(context, attrs) {private val binding = CustomViewBinding.inflate(LayoutInflater.from(context), this, true)init {binding.tvLabel.text = "Custom Component"}
}

四、与 DataBinding 对比

特性ViewBindingDataBinding
核心目的视图访问数据绑定 + 视图访问
布局变量支持❌ 不支持✅ 支持
表达式语言❌ 不支持✅ 支持
双向绑定❌ 不支持✅ 支持
性能开销⚡️ 零运行时开销⚠️ 有运行时开销
启用复杂度✅ 简单⚠️ 需额外配置
适用场景纯视图访问数据驱动UI

五、实践使用

  1. 空安全处理:Fragment 中使用解包模式

    private val binding get() = _binding!! 

  2. 多模块支持:在公共模块声明通用绑定

    interface BindableFragment<B : ViewBinding> {val binding: B
    }
  3. 适配器中使用:RecyclerView.ViewHolder 示例

    class UserViewHolder(val binding: ItemUserBinding) : RecyclerView.ViewHolder(binding.root) {fun bind(user: User) {binding.tvName.text = user.name}
    }
  4. 包含布局处理:合并 <include> 标签

    <include android:id="@+id/toolbar"layout="@layout/toolbar" />
    binding.toolbar.tvTitle.text = "Home"  // 直接访问子视图

六、问题解决方案

场景1:忽略某些布局文件

<LinearLayouttools:viewBindingIgnore="true">  <!-- 在根布局添加 -->

场景2:处理可选视图

<LinearLayouttools:viewBindingIgnore="true">  <!-- 在根布局添加 -->

场景3:兼容旧项目

// 与传统findViewById共存
val oldView = findViewById<TextView>(R.id.legacy_view)
binding.modernView.text = "New Approach"

七、性能分析

  1. 编译时生成:无运行时反射开销

  2. 内存占用:绑定对象仅存储视图引用

  3. Benchmark 数据

    • 视图访问速度比 findViewById 快 2-3 倍

    • 内存开销比 DataBinding 低 40%

http://www.dtcms.com/wzjs/799257.html

相关文章:

  • 潍坊网站建设联系方式邵武建设局网站
  • 网站301跳转代码网页小游戏源码
  • 双公示网站专栏建设网页分析从哪些方面
  • 学网站建设要什么北京建设信源公司网站
  • 厦门哪里有建设网站的建筑设计为何没人干了
  • 公司网站的意义免费动画制作网站
  • 嘉兴港区规划建设门户网站设计师招聘网站有哪些
  • 上线了做网站要钱工作证设计风格
  • 大连网站搜索排名提升开平网站建设
  • 番禺龙美村做网站做修图网站电脑配置
  • 凡科建站有哪些弊端洛可可设计公司待遇
  • 百度网站优化推广wordpress分类咋弄
  • 网站建设目的及意义建设小说网站首页
  • html网页导航栏模板网站开发使用api对seo
  • 网站上传不了照片网站维护计划
  • 贵阳大数据论坛seo外链推广平台
  • 钓鱼网站源码上海网站建设方案策划
  • 请人做网站需要注意什么哪里做网站优化
  • wordpress逻辑网站建设优化服务案例
  • 网站建设要如何选择网站为什么要ipc备案
  • seo网站优化服务网络广告创意
  • 湖北专业网站建设公司网站域名是指什么意思
  • godaddy怎么建设网站天津网站建设首选津坤科技
  • 网站设计怎么做明信片做编辑器的网站
  • 设计实例网站推推蛙贴吧优化
  • 网站设计机构互联网运营公司排行榜
  • 买过域名之前就可以做网站了吗wordpress加入夜间模式
  • 江苏建设行业证书编号查询网站网站分类查询
  • 实业有限公司网站怎么做课程商城网站模板
  • 昆明网站网站自己做自己的品牌好做