Here is my code
import React,{ Component } from 'react';
import PTSearch from 'post-api-search';
export default class Navbar extends Component{
constructor(props) {
super(props);
this.state = {
source: []
};
this.sourceSearch();
}
sourceSearch() {
PTSearch({
category: "",
language: "en",
country: ''
}, "sources", (sources) => {
this.setState({
source: sources
});
});
}
loadSourceContent() {
alert(1);
}
renderSource(data){
return (
<li title={data.description} onClick={this.loadSourceContent} key={data.name}>{data.name}</li>
);
}
render(){
return (
<div>
<button id="menu-toggle" className="menu-toggle"><span>Menu</span></button>
<div id="theSidebar" className="sidebar">
<button className="close-button fa fa-fw fa-close"></button>
<div>
<img src="https://vignette.wikia.nocookie.net/clonewarsadventurescharacter/images/8/81/Superman-logo-transparent.png/revision/latest?cb=20131006162105" />
</div>
<ul className="source-list">
{ this.state.source.slice(0, 10).map(this.renderSource) }
</ul>
</div>
</div>
);
};
}
I want to add an onclick event in each element of the li.But this code is not working for me. The issue is that when i click on <li>
element it gives loadsourcecontent
not defined error.
Thanks in advance and sorry about my English