附加按钮单击以访问webix数据表

时间:2015-09-08 14:15:50

标签: javascript onclick scope webix

我有以下代码,我想在webix数据表中添加记录。我是一个JS新手,所以不确定正确的定义,以确保变量范围有效。

基本上我有一个寻呼机和数据表就像这样工作正常:

    webix.ready(function(){

        webix.ui({
            id: "pagerA",
            view: "pager",
            template:"{common.prev()} {common.pages()} {common.next()}",
            container: "page_section",
            size: 15,
            group: 5
        });

        webix.ui({
            container:"gasforecast",
            rows: [
            {type: "header", template: "Gas Forecast"},
            gasgrid = {
            view:"datatable",
            editable: true,
            navigation: true,
            pager: "pagerA",
            columns:[
                { id:"PKey",            header:"",          hidden:true},
                { id:"SiteName",        header:"Site",      width:250, sort:"string"},
                { id:"PercentageChange",header:"% Change",  width:100, editor: "text", sort:"int"},
                { id:"kWChange",        header:"kW Change", width:100, editor: "text", sort:"int"}
            ],
            autoheight:true,
            autowidth:true,
            select:"row",

            save: "data/gasforecastdata_save.php",
            url: "data/gasforecastdata.php"
        }]});
    });

现在我希望能够有一个按钮,当点击它时会向数据表添加一行,所以我添加:

        cmdAddRow = webix.ui({
            container:"addbutton",
            view:"button",
            label: "Add Site",
            click: function() {
                var data = {"SiteName": "X", "PercentageChange": 1, "kWChange": 0};
                gasgrid.add(data);
            }

        });

然而,当单击该按钮时,它会生成一个' Uncaught TypeError:gasgrid.add不是函数'

我已经尝试将id:property添加到数据表并引用它,但我仍然收到错误。不知道该怎么办?

由于

加里

1 个答案:

答案 0 :(得分:1)

是的,ID的使用是正确的方法。

如果您更改下一个

的初始化代码
{ type: "header", template: "Gas Forecast"},
{ view:"datatable", id:"gasgrid", editable: true

稍后您将能够引用数据表并调用其API

webix.ui({
    container:"addbutton",
    view:"button",
    label: "Add Site",
    click: function() {
       var data = {"SiteName": "X", "PercentageChange": 1, "kWChange": 0};
       $$("gasgrid").add(data);
    }
})