【翻译】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 ...
随机推荐
- mysql中的 IN和FIND_IN_SET的查询问题
原来以为mysql可以进行这样的查询select id, list, name from table where 'daodao' IN (list); (一)注:1. table含有三个字 ...
- C++12!配对
题目内容:找出输入数据中所有两两相乘的积为12!的对数. 输入描述:输入数据中含有一些整数n(1<=n<232). 输出描述:输出所有两两相乘的积为12!的对数. 题目分析:对于输入的每个 ...
- 【译】Spark官方文档——Spark Configuration(Spark配置)
注重版权,尊重他人劳动 转帖注明原文地址:http://www.cnblogs.com/vincent-hv/p/3316502.html Spark主要提供三种位置配置系统: 环境变量:用来启动 ...
- Laravel 5 基础(十一)- 表单验证
在建立一个文章的时候,如果你什么都不输入直接提交,ok,你获得了一个空的文章,没有任何错误提示,这是不对的.在命令行下运行 php artisan 可以看到一个选项 make:request,新建一个 ...
- eclipse使用快捷键
注意热键冲突 内容补全键 Alt+/ 快速修复键 ctrl+1 代码移动 Alt+上下键(选中代码块) 左右移动 tab(右边)Shift+tab( ...
- 关于js中立即执行的匿名函数写法
/*最流行的写法*/ (function() { alert("run!") })(); /* !号可以有1~正无穷个,所以这一种就可以衍生无数种方式 */ !!!(functio ...
- GoogleMapApi 发布后提示安全问题
今天日本那边发过来一个Bug说是Google Map打不开,提示安全问题. 最后发现,日本那边的发布路径如下: https:xxxxx.gspserver.co.jp 而Source中Google M ...
- 任务管理界面添加显示RAM信息
显示RAM信息的核心代码是大蛋的,我只不过是整理下教程而已! 大蛋应该不会介意的吧,首先你需要apktool和SystemUI.apk,framework-res.apk 然后开始加载框架和反编译.. ...
- uva 11538 Chess Queen<计数>
链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&am ...
- linux 命令 more
more命令: 从前往后读取文件,启动时加载整个文件,让整个文件的内容从上到下显示在屏幕上. 可以逐页读取,空格(space):下一页,b键(back):上一页,而且还有搜索字符串的功能. more ...