【翻译】Sencha Touch2.4 The Layout System 布局
【翻译】The Layout System 布局
In Sencha Touch there are two basic building blocks: componentsand containers. When
you instantiate both with no configuration, they look the same. However, there is one
important difference: containers can containcomponents (or other containers):
在Sencha Touch中,有两个基本模块:组件(Components)和容器(Contaniners),如果不靠配置去实例化他们,也许你会发现他俩没啥区别,但是我要指出的是他们之间最大的不同便是,容器可以包含组件。
var container = Ext.create('Ext.Container', {
items: [{
xtype: 'component',
html: 'Nested component'
}, {
xtype: 'container',
items: [{
xtype: 'component',
html: 'Nested container with component'
}]
}]
});
Usually when containers hold other components, you want to think about how to po‐
sition these multiple components. Maybe you want to position the components on top
of each other, or maybe next to each other. In other words, you want to give the container
a layout.
通常来说,当容器内含有其他组件的时候,你需要思考如何定位这么多的组件,也许你想将他们排列在Top,也许你想将他们并排排列,换句话说,你想要一个布局。
Under the hood, Sencha Touch uses the CSS3 flexbox layout. This is different from Ext
JS 4, which uses JavaScript to dynamically calculate absolute CSS positions. The reason
for the difference is because Ext JS needs to support old legacy browsers (IE6, ouch!).
CSS3 flexbox layouts work only in modern browsers, and even here, there are multiple
implementations required to support multiple browsers. To understand CSS3 flexbox
layouts, take a look at “A Complete Guide to Flexbox”.
While implementing layouts in Sencha Touch (and in Ext JS), you do not need to worry
about the underlying CSS techniques—the framework takes care of it. That said, some
concepts, like flexing boxes in Sencha Touch (dynamic sizing), are similar to the CSS3
flexbox techniques
在底层,Sencha Touch使用Css3的FlexBox布局,这不同于以前的ExtJs4,后者因为要兼容老的浏览器,所以要利用Js去动态实现CSS定位,而Flex布局只运行在现代浏览器上,为了支持多种浏览器,css3提供了多种实现。
Ext.Componentis the base class for any Sencha Touch view component (widget).
Ext.Containeris the base class for any Sencha Touch component that may visually
contain other components. The most commonly used container classes for Sencha
Touch are Ext.Panel, Ext.tab.Panel, and Ext.form.Panel.Containers handle the
basic behavior for containing, inserting, showing, removing, and hiding items.
Ext.Component是SenchaTouch 视图组件(widget)中最基础的类,
Ext.Container是SenchaTouch 中包围着component(组件)的一种容器,通常用到的容器有Ext.panel, Ext.tab.Panel,Ext.form.Panel,容器拥有自己的操作方法,比如包含(containing)、插入(inserting)、显示(showing)、隐藏(hiding)、删除(removing)各种组件。
Speaking
of containing items, you might want to position items next to each other, or even on
top of each other. Some items should be bigger than others. You might want to give
those a fixed width and height, or even better, a height and width relative to the screen
size. You can achieve all of this while working with layouts. To make this concept clear,
we’ll see some screenshots of all the different layout types. The next examples explain
all the different layout types provided by the layout package.
对于被包含的组件来说,你可能想要去定位他们,摆放他们,或者是都放在Top层,一些组件可能比其它组件大和高,显得不是很协调,此时,你就需要去自适应宽度和高度,或者做的更好一些,就需要根据屏幕去自适应,你通过布局实现这一切你想要的效果,通过这一章节,我们会看到不同的页面布局效果,下一节我将讲解不同的布局类所带来的不同的布局方案
In this chapter, you’ll learn:
- How to implement a horizontal layout
- How to implement a vertical layout
- How to implement a full screen (fit) layout
- How to implement a card layout
- How to implement the default layout (no layout)
- How to dock components
在这个章节,你将学到
- 怎么实现一个横向布局
- 怎么实现一个竖向布局
- 怎么实现一个全屏(自适应)布局
- 怎么实现一个卡片布局
- 怎么实现一个默认布局(无布局)
- 怎么dock组件 (dock是固定在某个位置,比如Top或者Bottom)
- Hands-on Sencha Touch2 中文翻译
@落雨 ae6623.cn
【翻译】Sencha Touch2.4 The Layout System 布局的更多相关文章
- 【翻译】在Ext JS和Sencha Touch中创建自己定义布局
原文:Creating Custom Layouts in Ext JS and Sencha Touch 布局系统是Sencha框架中最强大和最独特的一部分.布局会处理应用程序中每个组件的大小和位置 ...
- [前端]使用JQuery UI Layout Plug-in布局 - wolfy
引言 使用JQuery UI Layout Plug-in布局框架实现快速布局,用起来还是挺方便的,稍微研究了一下,就能上手,关于该布局框架的材料,网上也挺多的.在项目中也使用到了,不过那是前端的工作 ...
- Understanding the WPF Layout System
Many people don't understand how the WPF layout system works, or how that knowledge can help them in ...
- 从 Auto Layout 的布局算法谈性能
这是使用 ASDK 性能调优系列的第二篇文章,前一篇文章中讲到了如何提升 iOS 应用的渲染性能,你可以点击 这里 了解这部分的内容. http://t.cn/Rc4KbUC 在上一篇文章中,我们提到 ...
- JQuery UI Layout Plug-in布局
端]使用JQuery UI Layout Plug-in布局 引言 使用JQuery UI Layout Plug-in布局框架实现快速布局,用起来还是挺方便的,稍微研究了一下,就能上手,关于该布 ...
- Sencha Touch2 工作笔记
Sencha Touch2 工作笔记 Ext.dataview.List activate( this, newActiveItem, oldActiveItem, eOpts ) Fires whe ...
- [前端]使用JQuery UI Layout Plug-in布局
引言 使用JQuery UI Layout Plug-in布局框架实现快速布局,用起来还是挺方便的,稍微研究了一下,就能上手,关于该布局框架的材料,网上也挺多的.在项目中也使用到了,不过那是前端的工作 ...
- Sencha Touch2 -- 11.1:定义具有关联关系的模型
在Sencha Touch2.0中,可以定义不同模型之间的关联关系.例如,在开发博客网站的时候,可以首先定义用户(User)模型,然后为用户定义文章(Article)模型.一个用户可以发表多篇文章,因 ...
- 【BZOJ1731】[Usaco2005 dec]Layout 排队布局 差分约束
[BZOJ1731][Usaco2005 dec]Layout 排队布局 Description Like everyone else, cows like to stand close to the ...
随机推荐
- PHP实例 表单数据插入数据库及数据提取 用户注册验证
网站在进行新用户注册时,都会将用户的注册信息存入数据库中,需要的时候再进行提取.今天写了一个简单的实例. 主要完成以下几点功能: (1)用户进行注册,实现密码重复确认,验证码校对功能. (2)注册成功 ...
- sliding windows (poj 2823) 题解
[问题描述] 给你一个长度为N的数组,一个长为K的滑动的窗体从最左移至最右端,你只能见到窗口的K个数,每次窗体向右移动一位,如下表: [样例输入] 8 3 1 3 -1 -3 5 3 6 7 [样例输 ...
- AngularJs记录学习03
AngularJs的路由是一个组件,需要自己额外添加,在目录/src/ngRoute中 三个文件route.js,routeParams.js,ngView.js <html> <h ...
- 配置php5.6的运行环境
所需要的原材料:(提供链接) php-5.6.10-Win32-VC11-x86 (zip)(注意php版本分为了IIS版和Apache版) httpd-2.4.12-x86-r2(apache) ( ...
- Sql Server数据的加密与解密
Sql Server数据的加密与解密 在sql server中,我们如何为数据进行加密与解密,避免使用者窃取机密数据? 对于一些敏感数据,如密码.卡号,一般不能使用正常数值来存储.否则会有安全隐患.以 ...
- Thread与Runable
当我们继承Thread的时候可以看出. 调用run()与start()来启动多线程是有区别. 如下我们开启多线程时 MyThread mt1 = new MyThread(“线程A”); MyThr ...
- 从零开始学ios开发(四):IOS控件(1),Image View、Text Field、Keyboard
长话短说,谢谢大家的关注,这篇写了好长时间,下面继续学习ios.我将用2到3篇的篇幅来学习iphone上的一些常用控件,包括Image View.Text Field.Keyboard.Slider等 ...
- 时隔3年半Spring.NET 2.0终于正式Release了
一直很喜欢Spring.NET,不过2011年8月2日1.3.2正式release之后,再没有正式版本的release了. 直到4天前,Spring.NET 2.0 GA终于Release. http ...
- verilog 学习笔记
1.在寄存器中: -1=1111 -2=1110 -3=1101 2.{1,0}=64‘H00000001_00000000;//默认是32位的位数-拼接: 3.defparam P1.Depth=1 ...
- Python实现Apriori
Python实现Apriori 运行环境 Pyhton3 计算过程 st=>start: 开始 e=>end: 结束 op1=>operation: 读入数据 op2=>ope ...