0

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 is not a function」が生成されます

id: プロパティをデータテーブルに追加して参照しようとしましたが、それでもエラーが発生します。何をすべきかわからない?

ありがとう

ゲイリー

4

1 に答える 1

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);
    }
})
于 2015-09-09T09:16:04.153 に答える