`
minzaipiao
  • 浏览: 148533 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

extjs 模板的自定义格式化

阅读更多
http://extjs.com/learn/Tutorial:Utilizing_Format_Features_of_Templates_(Chinese)

假设我们打算从一变量中,打印出内容,但当中的内容有可能会占用过多的空间。对于这种情况,通过的办法是对该内容截取,限制在50个英文字符内,然后做成连接让用户点击后观察全文。函数"ellipsis" 的功能正是这样,可限制在任意字符数内。另外,在截取字符串的后面,该函数还会加上“...“,以示实际的内容还有更多。

一个模板如下示

var myTpl = new Ext.Template(
    '<div>{content:ellipsis(50)}<br/><a href="{moreLink}">Read More</a></div>'
);

通过处理,其中有47个字符是属于内容本身的,另外三个字符是”...“,一共50个字符。

这是一份可用于模板格式化函数的列表:

    * ellipsis(length) - 对大于指定长度部分的字符串,进行裁剪,增加省略号(“...”)的显示。适用于只显示前N位的字符,然后提供详细页面的链接。
    * undef -检查一个值是否为underfined,如果是的转换为空值
    * htmlEncode - 转换(&, <, >, and ') 字符
    * trim - 对一段文本的前后多余的空格裁剪
    * substr(start, length) - 返回一个从指定位置开始的指定长度的子字符串。
    * lowercase - 返回一个字符串,该字符串中的字母被转换为小写字母。
    * uppercase - 返回一个字符串,该字符串中的字母被转换为大写字母。
    * capitalize - 返回一个字符串,该字符串中的第一个字母转化为大写字母,剩余的为小写。
    * usMoney - 格式化数字到美元货币。如:$10.97
    * date[(format)] - 将一个日期解析成为一个特定格式模式的日期。如日期字符串不输入,默认为“月/日/年”
    * stripTags - 剥去变量的所有HTML标签

您亦可以创建自定义的格式化函数,具体做法是,在模板的实例上加入新的方法,继而在模板上调用,格式化的函数应该像这样的:{VARIABLE:this.<formatfunction></formatfunction>}"

这是一个简单的实例,对模板实例加入一个"parseJson "的新函数。
var tplFun = new Ext.Template(
			'<table border=1 cellpadding=0 cellspacing = 0>',
			'<tr><td width=90 >姓名</td>',
			'<td width=120>{name}</td></tr>',
			'<tr><td width=90 >年龄</td>',
			'<td width=120>{age}</td></tr>',
			'<tr><td width=90 >身高</td>',
			'<td width=120>{stature:this.parseJson()}</td></tr>',
			'</table>'
		);
		var data = {
			name : 'tom',
			age : 24,
			stature : {
				num : 170,
				unit : '厘米'
			}
		}
		
		tplFun.parseJson = function(json){
			return json.num + json.unit;
		}
tplFun.append('tpl-table',data);
分享到:
评论

相关推荐

    extjs模板的使用

    2. **自定义格式化函数**: - `Ext.Template` 类允许你定义自己的格式化函数,如 `tpl2` 示例中,通过 `parseJson` 函数解析 JSON 对象,将 `stature` 字段的值组合成一个字符串返回。 - 使用时,可以在模板中调用...

    extjs4 模板值和模板

    EXTJS4的模板支持使用内置或自定义的格式化函数来处理模板值。例如: - 内置的`capitalize`函数可以将字符串的第一个字符转换为大写: ```javascript '{userName:capitalize}' ``` - 自定义的格式化函数可以...

    ExtJS 界面设计器

    ExtJS是一款强大的JavaScript库,主要用于...总的来说,ExtJS界面设计器是ExtJS开发者的强大辅助工具,它通过可视化设计方式简化了复杂的前端开发工作,提高了开发效率,使得开发者能够更专注于创造出色的用户体验。

    轻松搞定Extjs 带目录

    还可以自定义格式化函数,或者通过`XTemplate`进一步自定义内容。 #### 8. 组件结构 Extjs的组件结构复杂且功能强大,包括: - 组件分类:如窗口、面板、表单等。 - 组件生命周期:创建、渲染、销毁等。 - 组件...

    extjs可视化设计器

    5. **模板和样式**:学习EXTJS的模板语言(XTemplate)和CSS样式,定制组件的外观和格式。 6. **导出和导入代码**:知道如何将设计好的界面导出为EXTJS代码,并能将已有的EXTJS代码导入到设计器中进行编辑。 7. **...

    VS Code 搭配 Sencha Plugin 插件简直不要太好用.用于开发 ExtJS/ExtAngular

    Sencha Plugin是专门为VS Code设计的一款插件,它为ExtJS和ExtAngular的开发提供了诸多便利功能,例如代码提示、自动完成、错误检查、格式化等。安装这个插件后,开发者可以更轻松地编写和维护ExtJS或ExtAngular项目...

    extjs输入框检索补全

    ExtJS 支持自定义模板,你可以根据需要显示的数据结构来设计模板,比如显示标题、描述或者更多详细信息。 6. **用户体验优化**:为了让补全功能更加友好,还可以添加一些额外的特性,如自动选择最匹配项、提供清除...

    extjs.zip包

    3. **示例和模板**:演示EXTJS组件和功能的示例代码,以及基础模板,帮助初学者理解和学习。 4. **文档**:完整的API文档和用户指南,便于查阅和学习。 5. **构建工具**:用于编译、压缩和优化EXTJS应用的工具,如...

    Extjs 4.2分组小计

    使用`summaryRenderer`,结合Ext.XTemplate,可以创建包含多个统计信息和格式化的小计行。 总结,ExtJS 4.2的分组小计功能强大且灵活,能有效地帮助开发者构建具有数据分析功能的Web应用。通过理解并熟练运用上述...

    轻松搞定Extjs

    本章节重点介绍了Extjs提供的格式化工具。 - **用户需要优秀体验的内容**: 强调了良好的数据展示对于用户体验的重要性。 - **Ext.util.Format类**: 详细阐述了该类提供的各种格式化方法,如日期时间格式化、货币...

    ExtJS开发插件及Ext包

    - 它提供了代码补全、语法高亮、错误检查和自动格式化等功能,极大提高了开发效率。 - 对于ExtJS,Spket可以识别和理解ExtJS组件和API,提供实时的代码提示,帮助开发者快速编写代码。 - 还包括模板、调试工具和...

    extjs 5 combogrid控件

    7. **自定义列渲染**:通过column的renderer函数,可以对列数据进行格式化处理,例如日期格式化、数字格式化等。 8. **编辑功能**:如果Combogrid用在Ext.grid.Panel中,还可以启用编辑功能,直接在表格中修改选定...

    web流程设计器extjs做的design

    由于ExtJS的高度可扩展性,开发者可以根据需求添加自定义功能,如预览、导出流程图为图片或XML格式,或者集成第三方服务进行流程模拟和执行。此外,通过编写自定义插件,可以实现更多特定的流程设计需求。 **总结**...

    Extjs Combotree

    6. **模板化**:支持自定义模板,可以定制下拉列表中每个节点的展示样式和内容。 7. **无障碍性**:遵循无障碍网页设计原则,确保残障人士也能正常使用。 **使用步骤:** 1. **引入库文件**:确保引入了ExtJS 4.x...

    Extjs中文文档.pdf

    3. **格式化**:使用Ext.util.Format类对数据显示进行格式化处理。 #### 八、ExtJS组件结构 ExtJS的组件体系结构相对复杂,但理解这一部分对于深入学习非常关键。 **核心内容**: 1. **组件分类**:包括容器组件...

    extjs_tapestry.rar_extjs tapestry_extjs_tapestry_tapestry

    4. **JSON 数据交换**:Tapestry 和 ExtJS 都支持 JSON 格式的数据交换。Tapestry 可以通过其服务端组件暴露 JSON API,而 ExtJS 则通过 AJAX 请求获取并解析这些数据,更新视图。 5. **事件绑定**:Tapestry 有其...

    Extjs2.0中文文档

    5. **格式化**:Ext.util.Format类提供了多种格式化数据的方法,适用于格式化字符串、数字、日期等。文档会介绍这些方法的使用,以及如何与XTemplete配合使用。 6. **Extjs组件结构**:Ext.js是基于组件的框架,...

Global site tag (gtag.js) - Google Analytics