2017-11-28 13 views
0

私はJavaScriptクラス(ES6)を持っていますが、クラスによって作成されたボタンにそのクラスの関数を割り当てようとしています。このクラスでもあるクラスがtabDrawers本体にあるボタンを作成し、私は、関数openTab(インデックス)を割り当てる(addTab()に見られるように)タブが追加されます私のメインクラスJavascriptクラスボタンにクラス機能を割り当てます。

class tabDrawer { 
constructor(bodyID) { 
    this.bodyID = bodyID; 
    this.tabArray = []; 
    this.initialized = false; 
} 

get getBodyID() { 
    return this.bodyID; 
} 

initialize() { 
    this.body = document.getElementById(this.bodyID); 
    var baseHTML = "<div id='tabDiv'><div class='tab'></div><div class='tabContentDiv'></div></div>"; 
    this.body.innerHTML = baseHTML; 
    this.initialized = true; 
} 

addTab(tab) { 
    if(this.initialized) { 
     var tabClass = "tabLinks"; 
     if(this.tabArray.length === 0) { 
      tabClass += " active"; 
     } 
     console.log(this.tabArray.length); 
     this.body.children[0].children[0].innerHTML += "<button class='" + tabClass + "' id='btn" + tab.name + "'>" + tab.tabTitle + "</button>"; 
     this.body.children[0].children[1].innerHTML += "<div style='display: none' id='" + tab.name + "' class='tabContent'>" + tab.content + "</div>" 

     var tabButton = document.getElementById("btn" + tab.name); 
     tabButton.addEventListener("click", evt => this.openTab(evt)); 

     this.tabArray[this.tabArray.length] = tab; 
    } 
} 

openTab(index) { 
    var tabByIndex = this.tabArray[index]; 

    var i, tabcontent, tablinks; 

    // Get all elements with class="tabcontent" and hide them 
    tabcontent = document.getElementsByClassName("tabContent"); 
    for (i = 0; i < tabcontent.length; i++) { 
     tabcontent[i].style.display = "none"; 
    } 

    // Get all elements with class="tablinks" and remove the class "active" 
    tablinks = document.getElementsByClassName("tabLinks"); 
    for (i = 0; i < tablinks.length; i++) { 
     tablinks[i].className = tablinks[i].className.replace(" active", ""); 
    } 

    // Show the current tab, and add an "active" class to the button that opened the tab 
    document.getElementById(tabByIndex.name).style.display = "block"; 
    document.getElementById("btn" + tabByIndex.name).className += " active"; 
} 
} 

。私はクラスの代わりにボタンを参照するので、単に "this.openTab"とイベントリスナーを追加することはできません知っている。

行番号tabButton.addEventListener("click", evt => this.openTab(evt));が機能しているようですが、インデックスパラメータを関数に渡す方法がわかりません。この関数は、エンドユーザーもこの機能を利用できるようにするために、tabs.openTab(0);の "tabs "はtabDrawerのインスタンスです。

これはできますか?もしそうなら、どうしたらいいですか?

+0

@サルセータええと私はそれがうまくいかないと思っていましたが、動作しているように見えますが、私のように見える別の問題があるようです。いくつか試してみる – user265889

+0

スクリプトに関連してあなたのhtmlを共有できますか? – edkeveked

+0

@ user265889申し訳ありませんが、後で完全な回答を作成する方が適切だったので、コメントを削除します – Salketer

答えて

0

Document.createElement()を使用してHTML要素(innerHTMLではなく)を作成し、次に作成した要素にeventsを割り当てる必要があります。このような単純な:

var myClickMeFunction = function() { 
 
    alert('you clicked myClickMeFunction'); 
 
}; 
 

 
var button = document.createElement('button'); 
 
    button.classList.add('xxx'); 
 
    button.textContent = 'Click me'; 
 
    
 
    button.addEventListener('click', myClickMeFunction); 
 
    
 
document.body.appendChild(button);
.xxx { 
 
    background-color: orange; 
 
}

0

インデックスを渡すために、あなたはあなたのイベントにthis.tabArray.length代わりのevtを使用する必要があります。問題は、別のタブを追加する際に長さが変わるということですので、あなたは、スコープそれに必要があります。

var self = this; 
var handler = function (index){ 
    return function(){ 
     self.openTab(index); 
    } 
} 
tabButton.addEventListener("click",handler(this.tabArray.length)); 

これは、パラメータのインデックスを使用してイベントハンドラを作成するには、ハンドラ関数を実行します。

あなたは単純な厳しいやり方をすることができます...インデックスを必要とする唯一の理由は、tabArrayからタブをつかむことです!単にタブを直接渡すのではないのですか?

関連する問題