ExtJs之Ext.view.View

简介:

要注意MODEL的定义和实例化的代码,注释掉的是老式的不兼容4.0以上的。而下面的定义才是新推荐的。

我网上可是查的了。是书上的代码老了。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<! DOCTYPE html>
< html >
< head >
     < title >ExtJs</ title >
         < meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
     < link rel="stylesheet" type="text/css" href="ExtJs/packages/ext-theme-crisp/build/resources/ext-theme-crisp-all.css">
         < script type="text/javascript" src="ExtJs/ext-all.js"></ script >
         < script type="text/javascript" src="ExtJs/bootstrap.js"></ script >
         < script type="text/javascript" src="ExtJs/packages/ext-theme-crisp/build/ext-theme-crisp.js"></ script >
 
     < script type="text/javascript">
             Ext.onReady(function(){
         Ext.QuickTips.init();
         var inputForm = Ext.create('Ext.form.Panel', {
           bodyPadding: 5,
           width: 600,
           flex: 1,
           fieldDefaults: {
             labelSeparator: ': ',
             labelWidth: 80,
             width: 180,
             msgTarget: 'side',
             allowBlank: false,
             labelAlign: 'right'
           },
           layout: {
             type: 'hbox',
             align: 'middle'
           },
           defaultType: 'textfield',
           items: [{
             fieldLabel: '产品名称',
             name: 'productName'
           },{
             fieldLabel: '数量',
             xtype: 'numberfield',
             name: 'productNum'
           },{
             fieldLabel: '金额',
             xtype: 'numberfield',
             name: 'productPrice'
           }],
           fbar: [{
             text: '增加',
             handler: function(){
               if(inputForm.getForm().isValid()){
                 var data = inputForm.getForm().getValues();
                 //var product = Ext.ModelMgr.create(data, 'ProductInfo');
                 var product = Ext.create('ProductInfo', data);
                 productStore.add(product);
                 inputForm.getForm().reset();
               }
             }
           }]
         });
 
         //Ext.regModel('ProductInfo', {
         //  fields: ['productName', 'productNum', 'productPrice']
         //});
 
         Ext.define('ProductInfo', {
             extend: 'Ext.data.Model',
             fields: [
               {name: 'productName'},
               {name: 'productNum'},
               {name: 'productPrice'}
             ]
         });
 
         var productStore = Ext.create('Ext.data.Store', {
           autoLoad: true,
           data: [],
           model: 'ProductInfo',
           proxy: {
             type: 'memory',
             reader: {
               type: 'json',
               rootProperty: 'datas'
             }
           }
         });
 
         var productTpl = new Ext.XTemplate(
           '< table border=1 cellspacing=1 cellpadding=1 width=100%>',
           '< tr >< td width=160>产品名称</ td >< td width=75>数量</ td >< td width=75>金额</ td ></ tr >',
           '< tpl for=".">',
           '< tr >< td >{productName}</ td >< td >{productNum}</ td >< td >{productPrice}</ td ></ tr >',
           '</ tpl >',
           '</ table >'
         );
         var productView = Ext.create('Ext.view.View', {
           store: productStore,
           tpl: productTpl,
           deferEmptyText: false,
           itemSelector: 'div.thumb-wrap',
           emptyText: '请录入商品'
         });
 
         var productViewPanel = Ext.create('Ext.panel.Panel', {
           autoScroll: true,
           width: 600,
           flex: 3,
           layout: 'fit',
           bodyStyle: 'background-color: #FE5623',
           items: productView
         });
         Ext.create('Ext.panel.Panel', {
           renderTo: document.body,
           frame: true,
           width: 800,
           height:500,
           layout: 'vbox',
           title: '产品录入',
           items: [inputForm, productViewPanel]
         });
       });
     </ script >
</ head >
< body >
< div id='tpl-table1'></ div >
< br >
< div id='tpl-table2'></ div >
</ body >
</ html >

  

 

目录
相关文章
|
2月前
扩展EXT.BUTTON
扩展EXT.BUTTON
34 8
|
3月前
|
小程序 容器
微信小程序常用组件的简单使用 view,scroll-view,swiper,swiper-item,text,rich-text,button,image
本文介绍了微信小程序中常用组件的使用方法,包括view、scroll-view、swiper与swiper-item、text与rich-text、button以及image组件。详细解释了各组件的功能、属性以及如何在小程序页面中进行使用。
微信小程序常用组件的简单使用 view,scroll-view,swiper,swiper-item,text,rich-text,button,image
|
2月前
|
小程序 前端开发 JavaScript
小程序入门之认识view和text组件
小程序入门之认识view和text组件
79 0
|
小程序 前端开发 容器
【微信小程序】常用组件基本使用(view/scroll-view/swiper、text/rich-text、button/image)
【微信小程序】常用组件基本使用(view/scroll-view/swiper、text/rich-text、button/image)
242 0
|
API uml Android开发
Android | 深入理解View.post()获取宽高、Window加载View原理
深入理解View.post()获取宽高、Window加载View原理
434 0
|
Java
viewpage 添加fragment 报错 viewpage demo LayoutInflater 自定义控件轮播图demo
viewpage 添加fragment 报错 viewpage demo LayoutInflater 自定义控件轮播图demo
115 0
viewpage 添加fragment 报错 viewpage demo LayoutInflater 自定义控件轮播图demo
|
API 开发工具 UED
Using JavaFX UI Controls 12 Table View
原文链接地址:http://docs.oracle.com/javafx/2/ui_controls/table-view.htm#CJAGAAEE
234 0
Using JavaFX UI Controls 12 Table View
|
容器 数据安全/隐私保护 JavaScript
View组件
一、使用方法 view组件是最常用的,也是最简单的视图容器。它是一个块级容器组件,它没有特殊的功能,主要用于布局展示,是布局中最基本的UI组件。几乎所有复杂的布局都可以通过嵌套view来实现。 view除了公共属性之外,还有以下几个私有属性 属性名 类型 默认值 说明hover-.
3043 0