0

数値の代わりに ForigenKey 列のテキストを表示したいと考えています。IDを比較してTextMemberを取得する例はたくさんありますが、私の場合はうまくいきません。剣道UIを使い始めたばかりでよくわからない

コードは次のとおりです。

$(document).ready(function () {

 dataSource1 = new kendo.data.DataSource({

        transport: {
              read:  {
               url: "Data/AttendanceCode/GridSelect.php",
                dataType: "json",

                            },

                update: {
                   url: "Data/AttendanceCode/GridUpdate.php",
        dataType: "json",
                        type:"GET"
            },

                  destroy: {
                     url: "Data/AttendanceCode/GridDelete.php",
                      dataType: "json",
          type:"POST"
                            },

                    create: {
                      url: "Data/AttendanceCode/GridInsert.php",
                        dataType: "json",
              type:"POST"
                            },

                        },

                  schema: {
         data: "data",

                       model: {
                          id: "AttendenceID",

                           fields: {
                              AttendenceID : { editable: false, nullable: true },
                              TeacherID: { field: "TeacherID", defaultValue: "EIIT0002" },
                                }
                            }
                        },


                    });



$("#grid").kendoGrid({
           dataSource: dataSource1,

    pageSize: 10,
            pageable: {
                refresh: true,
                pageSizes: true
                    },
                    editable:{ mode : "popup" },
                    height: 400,
        filterable: true,
                    columnMenu: true,
        sortable: true, 
                    reorderable: true,
                    resizable: true,
                    toolbar: ["create"],

                    columns: [
                       { field:"AttendenceID", title: "Attendence ID", width:"130px" },

                       { field: "TeacherID", title:"Teacher", width: "100px" , editor: TeacherDropDownEditor, template: "#=getTeacherName(TeacherID)#" },

                   { command: ["edit", "destroy"], title: "Action", width: "210px" }],

                });


            });

Teacher DropDown DataSource

teacher = new kendo.data.DataSource({

       transport: {
         read: {
    url : "Data/Teacher.php",
    dataType: "json" }
               },

    schema: {
    data : "Teacher"
         }

    }); 

// 教師エディタ

 function TeacherDropDownEditor(container, options) {
   $('<input data-bind="value:' + options.field + '"/>')
.appendTo(container)
     .kendoDropDownList({         
     dataTextField: "TeacherName",
dataValueField: "Service_NO",
 dataSource: teacher
     });
}   

私が見つけて先生の名前を取得しようとしたさまざまなアプローチ

1 -

  function getTeacherName(value) {

          var text = "";
     $.each(teacher, function () {
           if (this.Service_NO == value) {
            text = this.Name;
             return false;
           }
        });
     return text;
                      }

2 -

function getTeacherName(teacherID) {

 for (var idx = 0, length = teacher.length; idx < length; idx++) 
   {
    if (teacher[idx].Service_NO === teacherID) 
       {t = teacher[idx].Name;} 
    }                   
return t; 
    }

3 -

function getTeacherName(teacherID) {
      $.each(teacher, function(key, val) {
        if(val.Service_NO == tID){
           t = val.Name;
            }
             });
           return t;
            } 

dataSource (教師) には値がないようです。PHPコードは完全に機能しています。私のコードの何が問題なのかがわかったら、助けてください。

ありがとう !!

4

2 に答える 2

0

そうです、teacherDataSource にはデータがありません。データを取得する方法を定義しているため (それが DataSource で行うことです)、それを読み取っていないからです。

追加:

teacher.read();

データの読み取りを手動で強制するため。

注:これは、Grid、ListView などがある場合に魔法のように発生するものですが、これらのウィジェットが自動的に実行するためですが、今回は、JavaScript 関数から呼び出されるため、グリッドを表示するために事前に読み取る必要があります ( KendoUI グリッド コードはgetTeacherName、名前以外に関数に含まれているものについて何も知りません)。

于 2013-01-31T21:53:14.157 に答える
0

フィールドを設定する必要があります:

{ field: "nu_status", title: 'Status', values: [ { text: "Active", value: 1 }, { text: "Inactive", value: 0 }]},
于 2017-05-04T18:21:13.197 に答える