2017-05-18 21 views
0

ねえ、私はAngularでいくつかの問題を抱えています。 私はオブジェクトの配列と2つの関数を持っていますが、そのうちの1つに配列は定義されていません。 だから私の機能があります。配列が定義されていないのはなぜですか?

  • でgetTarget()
  • でsaveChanges()
  • アドユーザー()
  • drawTable()
  • ngOnInit() 私はconsole.logにしようとしている私これらすべての機能の配列は、すべてOKですが、getTarget()機能です!他の機能の出力が(2) [Object, Object]の場合はundefinedをコンソールに記録するだけです。 なぜアレイに到達できないのですか?

これは私のアプリのコードです:

row.addEventListener('click',this.getTarget.bind(this),false) 

またはに

import {Component, OnInit} from '@angular/core'; 

var ID:number; 

export class entity { 
    id:number; 
    name:string; 
    lName:string; 
} 


let USERS: entity[] = [ 
    {id: 0, name: 'Jon Smith', lName: 'Last Name'}, 
    {id: 1, name: 'qwe asd', lName: '123'} 
]; 

@Component({ 
    selector: 'my-app', 
    templateUrl: './template.html', 
}) 

export class AppComponent implements OnInit{ 
    name = 'Angular'; 
    Users = USERS; 

    /*deleteUser() { 
     console.log(ID); 
     delete this.Users[ID]; 
     this.drawTable(); 
    }*/ 
    getTarget() { 
     let Target = event.target; 
     let id = $(<HTMLButtonElement>Target).parent().parent().attr('id'); 
     console.log('номер',id); 
     console.log(this.Users); 
     ID = parseInt(id); 
     //console.log($(<HTMLButtonElement>Target).text()); 
      if ($(<HTMLButtonElement>Target).text()=='Удалить'){ 
       /*this.Users = this.Users.slice(ID,1); 
       this.drawTable();*/ 
       console.log(this.Users); 
      } 
    } 
    saveChanges(id:number) { 
     id = ID; 
     $(<HTMLButtonElement>event.target).attr('data-dismiss', 'modal'); //Закрыть модальное окно 
     $('#editErrorMessage').attr('style','visibility:hidden');//сделать сообщение об ошибке невидимым 
      if (($('#editNameInput').val() != '') && ($('#editLNameInput').val()!='')) { 
       this.Users[id].name = $('#editNameInput').val();//сохранить новые значения 
       this.Users[id].lName = $('#editLNameInput').val(); 
       $('#editNameInput').val('');//очистить 
       $('#editLNameInput').val('');//инпуты 
       this.drawTable(); 
      } 
      else { 
       $(<HTMLButtonElement>event.target).removeAttr('data-dismiss');// не закрывать модальное окно 
       $('#editErrorMessage').removeAttr('style');//сообщение снова видно 
      } 
    } 
    addUser() { 
     $(<HTMLButtonElement>event.target).attr('data-dismiss', 'modal'); //Закрыть модальное окно 
     $('#addErrorMessage').attr('style','visibility:hidden');//сделать сообщение об ошибке невидимым 
     if (($('#addNameInput').val() != '') && ($('#addLNameInput').val() != '')) 
     { 
      let tempObj:entity = {id: this.Users.length, name: $('#addNameInput').val(), lName: $('#addLNameInput').val()}; 
      this.Users.push(tempObj); 
      $('#addNameInput').val(''); 
      $('#addLNameInput').val(''); 
      this.drawTable(); 
     } 
     else { 
      $(<HTMLButtonElement>event.target).removeAttr('data-dismiss');// не закрывать модальное окно 
      $('#addErrorMessage').removeAttr('style');//сообщение снова видно 
     } 
    } 
    drawTable() { 
     console.log('drawing', this.Users); 
     let Table = $('table'); 
     let tBody = $('tbody'); 
     console.log(this.Users.length); 
     tBody.empty(); 
     //элементы таблицы 
      /*for (let rowIndex = 0; rowIndex == this.Users.length - 1; rowIndex++) { 
       console.log(rowIndex); 
       console.log(this.Users[rowIndex]); 
       row.dataset.id = this.Users[rowIndex].id.toString(); // установить id строки 
        cell.innerHTML = this.Users[rowIndex].id.toString(); // текст внутри ячейки 
       row.appendChild(cell); // добавить ячейку в ряд 
        cell.innerHTML = this.Users[rowIndex].name; 
       row.appendChild(cell); 
        cell.innerHTML = this.Users[rowIndex].lName; 
       row.appendChild(cell); 
        cell.innerHTML = ''; // убрать текст из ячейки 
         editButton.className = 'crud__DeleteEditButton form-control'; //настройка кнопки изменения 
         editButton.setAttribute('data-toggle', 'modal'); 
         editButton.setAttribute('data-target', '#editModal'); 
         editButton.setAttribute('onclick','getTarget()'); 
         editButton.innerHTML = 'Изменить'; 
        cell.appendChild(editButton); // добавить кнопку в ячейку 
       row.appendChild(cell); 
         deleteButton.className = 'crud__DeleteEditButton form-control'; //настройка кнопки удаления 
         deleteButton.setAttribute('onclick','deleteUser()'); 
         deleteButton.innerHTML = 'Удалить'; 
        cell.appendChild(deleteButton); 
       tBody.appendChild(row); //добавить строку в таблицу 
      };*/ 
      for (let item of this.Users){ 
       console.log('start'); 
       let row = document.createElement('tr'); 
       let cells = []; 
       let editButton = document.createElement('button'); 
       let deleteButton = document.createElement('button'); 
        row.setAttribute('id',item.id.toString()) // установить id строки 
       let cell1 = document.createElement('th'); 
        cell1.innerHTML = item.toString(); // текст внутри ячейки 
        cells.push(cell1); 
       console.log(cells); 
       let cell2 = document.createElement('th'); 
        cell2.innerHTML = item.name; 
        cells.push(cell2); 
       console.log(cells); 
       let cell3 = document.createElement('th'); 
        cell3.innerHTML = item.lName; 
        cells.push(cell3); 
       console.log(cells); 
        editButton.className = 'crud__DeleteEditButton form-control'; //настройка кнопки изменения 
        editButton.setAttribute('data-toggle', 'modal'); 
        editButton.setAttribute('data-target', '#editModal'); 
        editButton.innerHTML = 'Изменить'; 
       let cell4 = document.createElement('th'); 
        cell4.appendChild(editButton); 
        cells.push(cell4); 
       console.log(cells); 
        deleteButton.className = 'crud__DeleteEditButton form-control'; //настройка кнопки удаления 
        //deleteButton.addEventListener('click',this.deleteUser,false) 
        deleteButton.innerHTML = 'Удалить'; 
       let cell5 = document.createElement('th'); 
        cell5.appendChild(deleteButton); 
        cells.push(cell5); 
       console.log(cells); 
        for (let tempCell of cells){ 
         console.log('appending'); 
         row.appendChild(tempCell); 
        } 
        row.addEventListener('click',this.getTarget,false) 
        tBody.append(row); //добавить строку в таблицу 
      } 
      Table.append(tBody); // добавить тело к таблице 
      console.log('drawing done'); 
    } 
    ngOnInit():void { 
     this.drawTable(); 
    } 
} 

(ロシアカントーのため申し訳ありません)

+0

あなたは 'USERS'(大文字)として配列名を宣言した、あなたは' this.Users'を使用しています。 – abhishekkannojia

+0

@abhishekkannojia:彼はまた、 'AppComponent'に' Users = USERS; 'を持っています。 –

+0

@ T.J.Crowderああ私の悪い、それを見ていない。 – abhishekkannojia

答えて

2

変更

row.addEventListener('click',this.getTarget,false) 
row.addEventListener('click',() => this.getTarget(),false) 

これは、そうでない場合はあなたのコンポーネントを参照していません。

推奨読書:How to access the correct `this` context inside a callback?

+1

うんを参照してくださいあなたの –

+0

*「推奨読書に感謝: '正しいアクセスする方法このコンテキストはコールバックの中にありますか?」*質問が重複している場合は、それに答えるのではなく、重複として閉じて投票します。 JavaScriptタグのゴールドバッジホルダーとして、私はデュエルマスターを持っていると信じています。 –

+0

@TJCrowder私はより多くの先生に同意できませんでしたが、私はこれらのタイプの質問に印を付けると、私の質問に関連していますか? "これが正式なコメントです。だから私はすぐに質問に答えて、問題の原因へのリンクを与えます。 OPがそれを読んだ場合、そうでなければ利益になる。ケースはすでに閉鎖されている。別のケースは私が質問にフラグを立てることで、質問は私の答えのタイプで答えられ、このように受け入れられます。私は金のバッジを取得すると、私は彼らに遭遇した場合の質問のこれらの種類をロックするが、それまではよ、これは良さそうです:/ – echonax

関連する問題