ExtJs之Ext.grid.GridPanel(部分未完)
今天在家休息,年假不用就作费啊。
看了几部香港老电影,陪爸爸看了勇士占奇才,
然后,测试了一下EXTJS未完的内容,
在京东上订了七本历史普及书,近两百块。。:)
搞定。
<!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>
<style type="text/css">
#uses the following css:
.red-row{ background-color: #F5C0C0 !important; }
.yellow-row{ background-color: #FBF8BF !important; }
.green-row{ background-color: #99CC99 !important; }
</style>
<script type="text/javascript">
Ext.onReady(function(){
function rendererSex(value){
if (value == 'male') {
return "<span style='color:red;font-weight: bold;'>男</span>";
}else {
return "<span style='color:green;font-weight: bold;'>女</span>";
}
};
function rendererDescn(value, cellmeta, record, rowIndex, columnIndex, store){
var str = "<input type='button' value='查看详细信息' onclick='alert(\"" +
"这个单元格的值为: " + value + "\\n" +
"这个单元格的配置是: {cellID" + cellmeta.cellID + ", id: " + cellmeta.id + ", css: " + cellmeta.css + "}\\n" +
"这个单元格对应的record是: " + record + ", 一行里的数据都在里边\\n" +
"这是第" + rowIndex + "行\\n" +
"这是第" + columnIndex + "列\\n" +
"这个表格对应的Ext.data.Store在这里: " + store + ", 随便用吧." +
"\")'>"
return str;
}
function rendererMotif(data, cell, record, rowIndex, columnIndex, store) {
var value = record.get('color');
cell.style = "background-color: " + value;
return data;
}
var sm = new Ext.selection.CheckboxModel({stringSelect: true});
var columns =[
new Ext.grid.RowNumberer(),
{header: '编号', dataIndex: 'id', width:80, sortable: false},
{header: '名称', dataIndex: 'name', width:180},
{header: '性别', dataIndex: 'sex', renderer: rendererSex, width:120},
{header: '日期', dataIndex: 'date', renderer: Ext.util.Format.dateRenderer('Y-m-d'), width:400},
{header: '描述', dataIndex: 'descn', renderer: rendererDescn, width:200},
{header: 'color', dataIndex: 'color', renderer: rendererMotif, width:200}
];
var data = [
['1', 'name1', 'male', '2017-01-15T02:58:04', 'descn1', '#FBF8BF'],
['2', 'name2', 'female', '2005-01-15T02:58:04', 'descn2', '#F5C0C0'],
['3', 'name3', 'male', '2017-06-15T02:58:04', 'descn3', '#99CC99'],
['4', 'name4', 'female', '2017-01-09T02:58:04', 'descn4', '#FBF8BF'],
['5', 'name5', 'male', '2017-12-15T02:58:04', 'descn5', '#F5C0C0']
];
var store = new Ext.data.ArrayStore({
data: data,
fields: [
{name: 'name', mapping: 1},
{name: 'sex', mapping: 2},
{name: 'id', mapping: 0},
{name: 'date', type: 'date', dateFormat: 'Y-m-dTH:i:s', mapping: 3},
{name: 'descn', mapping: 4},
{name: 'color', mapping: 5}
]
});
/*
var store = new Ext.data.Store({
proxy: new Ext.data.ScriptTagProxy({url: 'source.html'}),
reader: new Ext.data.ArrayReader({}, [
{name: 'id'},
{name: 'name'},
{name: 'descn'}
]),
fields: [
{name: 'name', mapping: 1},
{name: 'id', mapping: 0},
{name: 'descn', mapping: 2}
]
});
*/
store.load();
var grid = new Ext.grid.GridPanel({
enableColumnMove: false,
enableColumnResize: true,
stripeRows: true,
autoHeight: true,
loadMask:true,
forceFit: true,
renderTo: 'grid',
store: store,
columns: columns,
selModel: sm,
bbar: new Ext.PagingToolbar({
pageSize: 3,
store: store,
displayInfo: true,
displayMsg: '显示第{0} 条到 {1}条记录, 一共{2}条',
emptyMsg: '没有记录'
}),
viewConfig: {
enableRowBody: true,
columnsText: '显示的列',
sortAscText: '升序',
getRowClass: function(record, rowIndex, p, ds) {
var cls = 'white-row';
switch (record.data.color) {
case '#FBF8BF' :
cls = 'yellow-row';
break;
case '#99CC99' :
cls = 'green-row';
break;
case '#F5C0C0' :
cls = 'red-row';
break;
}
return cls;
}
}
});
Ext.get('remove').on('click', function(){
store.remove(store.getAt(1));
grid.view.refresh();
})
var tree = new Ext.tree.TreePanel({
store: new Ext.data.TreeStore({
root: {
text: '我是根',
children: [{
text: '我是根的第一个枝子',
children: {
text: '我是根的第一个枝子的第一个叶子',
leaf: true
}
},{
text: '我是根的第一个叶子',
leaf: true
}]
}
})
});
tree.render('tree');
});
</script>
</head>
<body style="margin: 20px">
<div id='grid' style="width: 800px"></div>
<button id='remove'>删除第二行</button>
<div id="tree"></div>
</body>
</html>

ExtJs之Ext.grid.GridPanel(部分未完)的更多相关文章
- ExtJs的Ext.grid.GridPanel不能选择复制表格中的内容解决方案
今天遇到grid复制的问题,在网上找到了一个解决办法,只需改下CSS和JS,给大家分享一下: 本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/dy_paradise/a ...
- 【编程技巧】EXTJS中Ext.grid.GridPanel配置项autoExpandColumn的使用方法
autoExpandColumn的作用是自动伸展,占满剩余区域.一般使用在列比较少,并且大多数列都比较窄,有一列比较宽的情况下,当然什么时候使用,还是得按照实际情况确定. 使用的时候主要有三点要注意的 ...
- Ext.grid.GridPanel属性及方法等
1.Ext.grid.GridPanel主要配置项:store:表格的数据集columns:表格列模式的配置数组,可自动创建ColumnModel列模式autoExpandColumn:自动充满表格未 ...
- Ext.grid.GridPanel的属性
1.Ext.grid.GridPanel 主要配置项: store:表格的数据集 columns:表格列模式的配置数组,可自动创建ColumnModel列模 ...
- [Extjs] Ext4 Ext.grid.Panel 分页实现(mybatis 分页插件-PageHelper 使用)
先看图: 页面js代码: var userStore=Ext.create('Ext.data.Store', { storeId:'userStore', fields:['uname', 'ema ...
- Ext.grid.GridPanel数据转json
var count = docAdGrid.getStore().getCount(); var jsonArray = []; for (var i = 0; i < count; i++) ...
- ExtJs4.2.1中的Ext.grid.GridPanel选择行回车事件
网上大多说的是“rowdblclick” 其实是“itemdblclick” 这个东西坑了我一上午.
- [转] Ext Grid (ExtJs)上的单击以及双击事件
例1: 1.双击 var cb = new Ext.grid.RowSelectionModel({ singleSelect:true //如果值是false,表明可以选择多行:否则只能选择一行 } ...
- Ext4.0.7使用Ext.grid.ColumnModel报错:TypeError: Ext.grid.Model is not a constructor
代码如下: Ext.onReady(function(){ //定义列 var cm = new Ext.grid.ColumnModel([ {header: '编号', dataIndex: 'i ...
随机推荐
- outlook创建收信规则,将收到的所有邮件,转发到qq邮箱,然后删除
因为outlook默认只有400M的空间. 使用企业邮箱的时候,很快就满了. 本来是打算在qq邮箱中,添加其他邮箱来收取的. http://service.mail.qq.com/cgi-bin/he ...
- bzoj 1800 & 洛谷 P2165 [AHOI2009]飞行棋 —— 模拟
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1800 https://www.luogu.org/problemnew/show/P21 ...
- 对ip数据进行分类----c++
#!/usr/bin/expect set ip [lindex $argv ] set password [lindex $argv ] spawn -l root ${ip} "host ...
- codeforces round #420 div2
A:暴力枚举 模拟 #include<bits/stdc++.h> using namespace std; ; int n; int a[N][N]; int main() { scan ...
- vmware centos7 没有网络设备
vmware centos7 没有网络设备 选择VMware 虚拟机模拟器为CentOS 64 即可;
- Stick ------ 剪枝神题
这个是自己剪得 , 我感觉已经很不错了 但是不知道哪里出了问题 一直 超时 // 根据所给答案 和 题目要求 最直观的就可以有剪枝的地方 而且 剪枝剪得越早 就越省时省力 // 好的思路也可以省 ...
- java selenium启动火狐浏览器报错:Cannot find firefox binary in PATH. Make sure firefox is installed. OS appears to be: VISTA Build info: version: '3.8.1', revision: '6e95a6684b', time: '2017-12-01T19:05:14.666Z
Cannot find firefox binary in PATH. Make sure firefox is installed. OS appears to be: VISTA Build in ...
- 利用windbg获取dump的dll文件
根据堆栈对应的地址查找其对应的Module ID,然后将对应的Module保存. !IP2MD 命令从托管函数中获取 MethodDesc 结构地址. !dumpmodule 1caa50 下面的命令 ...
- 06-联系人管理(xib应用)
ViewController.h文件中: @interface ViewController : UIViewController - (IBAction)add:(UIBarButtonItem * ...
- 编译带加密功能的sqlite
以为编译wxsqlite是很难的事情,竟然这么顺利. 1.下载wxsqlite代码,解压(wxcode.sourceforge.net/components/wxsqlite3/) 2.下载Prema ...