如何高性能布局

简介: RelativeLayout Vs LineLayout 尽可能的使用RelativeLayout,不要使用绝对布局AbsoluteLayout,在布局层次一样的情况下,建议使用LineLayout代替RelativeLayout,因为LineLayout性能要稍高一点,但往往RelativeLayout可以实现LineLayout嵌套才能实现的布局。
  1. RelativeLayout Vs LineLayout
尽可能的使用RelativeLayout,不要使用绝对布局AbsoluteLayout,在布局层次一样的情况下,建议使用LineLayout代替RelativeLayout,因为LineLayout性能要稍高一点,但往往RelativeLayout可以实现LineLayout嵌套才能实现的布局。

 2. include
在实际开发中,我们经常会遇到一些公用的UI组件,比如导航栏,如果每个布局文件中都去在xml里面写相关代码,将会产生大量的工作量。同时如果要对布局发生改变,需要修改很多xml里面的代码,通过include可以实现在多个布局文件中引用同一块布局文件,或者采用组合控件的方式代替include也是不错的选择。
 
 3.   viewStub
懒加载,viewstub标签同include标签一样可以用来引入一个外部布局,不同的是,viewstub引入的布局默认不会扩展,既既不会占用位置,从而在解析layout布局文件的时候节省cpu和内存,viewstub常用来引入那些默认不显示,只有在特殊情况下显示的布局,如加载布局,网络失败布局,显示的刷新布局,形式出错的提示布局等。
 
  4. merge
合并UI布局,有些时候lint工具会给出提升,所以可以依靠android的lint工具去使用merge去修改和优化布局文件,使用该标签主要是减少布局的嵌套层次。
 
布局根节点为framelayout且不设置background或者padding等属性,可以使用merge来代替,因为可以用merge消除一个节点。
 
某布局作为子布局被其他布局include时候,使用merge当作该布局的顶点,这样在被引入时顶节点会被自动忽略,而其子节点全部合并主布局里面去。
 
笔记是在学习麦子学院视频过程中整理的,大家没事也可以上去学习下,有很多技术类的在线视频
http://www.maiziedu.com/course/android/

 

相关文章
|
1天前
|
前端开发 容器
弹性布局是?
弹性布局是?
|
1月前
|
编解码 前端开发 UED
前端需要完完全全掌握的这些布局方案
前端需要完完全全掌握的这些布局方案
|
8月前
|
前端开发 容器
前端中关于弹性布局的应用
前端中关于弹性布局的应用
|
8月前
|
网络协议 Linux Perl
如何构建 Sidecarless 模式的高性能服务网格
如何构建 Sidecarless 模式的高性能服务网格
|
9月前
|
前端开发 UED 容器
深入了解Flex布局:构建灵活响应式布局的利器
深入了解Flex布局:构建灵活响应式布局的利器
123 1
|
9月前
|
人工智能 前端开发 搜索推荐
前端布局和兼容
阅读报纸时容易发现,虽然报纸中的内容很多,但是经过合理地排版,版面依然清晰、易读。同样,在 制作网页时,要想使页面结构清晰、有条理,也需要对网页进行“排版”。 “版心”(可视区) 是指网页中主体内容所在的区域。一般在浏览器窗口中水平居中显示,常见的宽度值为 960px、980px、1000px、1200px等。
69 0
|
前端开发
前端学习案例3-弹性布局3
前端学习案例3-弹性布局3
39 0
前端学习案例3-弹性布局3
|
前端开发
前端学习案例2-弹性布局2
前端学习案例2-弹性布局2
44 0
前端学习案例2-弹性布局2
|
前端开发
前端学习案例1-弹性布局1
前端学习案例1-弹性布局1
52 0
前端学习案例1-弹性布局1
|
前端开发
传统布局的那些事
首先我们来链接一下css的三种定位机制分别是普通流,浮动,定位
52 1