admin管理员组文章数量:1345078
I'm using this react library: , I have created a simple Component like this:
export default class Sample extends Component {
ponentDidMount() {
console.log("Mount");
}
render () {
return (
<div>
Hello
</div>
);
}
}
And I have inserted it inside the tabs in my sample app:
import React, { Component } from 'react';
import { render } from 'react-dom';
import { Tab, Tabs, TabList, TabPanel } from 'react-tabs';
import Sample from './Sample.jsx';
class App extends Component {
handleSelect(index, last) {
console.log('Selected tab: ' + index + ', Last tab: ' + last);
}
render() {
return (
<Tabs
onSelect={this.handleSelect}
selectedIndex={2}
>
<TabList>
<Tab>Foo</Tab>
<Tab>Bar</Tab>
<Tab>Baz</Tab>
</TabList>
<TabPanel>
<Sample />
</TabPanel>
<TabPanel>
<Sample />
</TabPanel>
<TabPanel>
<Sample />
</TabPanel>
</Tabs>
);
}
}
render(<App/>, document.getElementById('container'));
And every time I switch Tab the ponentDidMount
is called and I can see the Mount
log in the console. My question is how can avoid calling the ponentDidMount
method every time, but calling it only the first time? I make this question because I want add an Ajax call inside it and I don't want make the Ajax call every time I switch the tab, but only one time.
Thanks
I'm using this react library: https://github./reactjs/react-tabs, I have created a simple Component like this:
export default class Sample extends Component {
ponentDidMount() {
console.log("Mount");
}
render () {
return (
<div>
Hello
</div>
);
}
}
And I have inserted it inside the tabs in my sample app:
import React, { Component } from 'react';
import { render } from 'react-dom';
import { Tab, Tabs, TabList, TabPanel } from 'react-tabs';
import Sample from './Sample.jsx';
class App extends Component {
handleSelect(index, last) {
console.log('Selected tab: ' + index + ', Last tab: ' + last);
}
render() {
return (
<Tabs
onSelect={this.handleSelect}
selectedIndex={2}
>
<TabList>
<Tab>Foo</Tab>
<Tab>Bar</Tab>
<Tab>Baz</Tab>
</TabList>
<TabPanel>
<Sample />
</TabPanel>
<TabPanel>
<Sample />
</TabPanel>
<TabPanel>
<Sample />
</TabPanel>
</Tabs>
);
}
}
render(<App/>, document.getElementById('container'));
And every time I switch Tab the ponentDidMount
is called and I can see the Mount
log in the console. My question is how can avoid calling the ponentDidMount
method every time, but calling it only the first time? I make this question because I want add an Ajax call inside it and I don't want make the Ajax call every time I switch the tab, but only one time.
Thanks
Share Improve this question edited Mar 5, 2017 at 23:50 Dimitris Karagiannis 9,3969 gold badges45 silver badges74 bronze badges asked Mar 5, 2017 at 23:20 PieroPiero 9,27321 gold badges93 silver badges162 bronze badges3 Answers
Reset to default 6You can use forceRenderTabPanel={true}
on the <Tabs/>
ponent so that the tabs stay mounted.
<Tabs
onSelect={this.handleSelect}
selectedIndex={2}
forceRenderTabPanel={true}
>
I have just had the same problem. All your ponents need to exist at the same time and use this.STATE.tabIndex and CSS to control the invisibility.
Create the Tabs with controlled mode:
class App extends Component {
constructor() {
super();
this.state = { tabIndex: 0 };
}
render() {
return (
<Tabs onSelect={tabIndex => this.setState({ tabIndex })}>
<TabList>
<Tab>Title 1</Tab>
<Tab>Title 2</Tab>
</TabList>
<div style={this.state.tabIndex===0 ?
{display:"block"}: {display:"none"}} >
</div>
<div style={this.state.tabIndex===0 ?
{display:"block"}: {display:"none"}} >
</div>
</Tabs>
);
}
}
Every time React adds a ponent to the DOM ponentDidMount
will fire, there is no way around that.
In your case, when you switch tabs, I assume that React unmounts the current content of the TabPanel
ponent and mounts the new content, which is your Sample
ponent, which in turn, once mounted, will fire the ponentDidMount
method.
Depending on what your AJAX call returns, you should probably rethink where to place the AJAX call.
本文标签: javascriptreact tabs call componentDidMount every time when switching tabStack Overflow
版权声明:本文标题:javascript - react tabs call componentDidMount every time when switching tab - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743781835a2537972.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论