aardio 文档

aardio 范例: 简单数据视图 - 双击编辑单元格(可指定只读列)

//简单数据视图 
import win.ui;
/*DSG{{*/
var winform = win.form(text="简单数据视图 - 双击编辑单元格(可指定只读列)";right=1031;bottom=712)
winform.add(
edit={cls="edit";left=25;top=584;right=997;bottom=693;edge=1;multiline=1;z=2};
listview={cls="listview";left=24;top=27;right=996;bottom=555;edge=1;z=1}
)
/*}}*/

import win.ui.grid;
var grid = win.ui.grid(winform.listview);//创建数据视图
grid.setReadonlyColumns(1);//可选设置禁止编辑的列,设为 -1 禁止编辑所有列
grid.setColumns({"ID";"日期";"标题"}) //可选自定义显示列名

import sqlite;
var db = sqlite("/testParameters.db");
db.exec( "CREATE TABLE IF NOT EXISTS @tablename(id INTEGER PRIMARY KEY, date, title);",{
    tablename = "myTableName"
} ) 

var cmd = db.prepare("INSERT INTO myTableName VALUES (NULL,@date,@title);" );
for(i=1;10;1){
    cmd.step(
        date = time().addday( math.random(1,30));
        title = string.random(15);
    )
}

//直接支持常用数据库的 getTable 函数返回的数据格式
var dataTable = db.getTable("SELECT * FROM [myTableName] ");

//直接让 listview 控件显示数据库的查询结果
grid.setTable( dataTable )

//编辑变更值会触发下面的事件
grid.onEditChanged = function(text,iItem,iSubItem){
    var name = dataTable.fields[iSubItem]
    winform.edit.print(dataTable[iItem][name],"-->",text);
    dataTable[iItem][name] = text;
} 

/*
用户点击列头排序时会触发下面的事件,
column 为列号,desc 参数指定是否倒序
*/
grid.onSortColumn = function(column,desc){
    var name = dataTable.fields[column];
    table.sort(dataTable,desc ? (lambda(next) owner[name] > next[name]) : (lambda(next) owner[name] < next[name])); 

    grid.setTable( dataTable );
    return true; //返回 true 允许当前列排序
}

winform.show() 
win.loopMessage();

Markdown 格式