How to Programmatically Scroll Drawer in Material UI React JS?
Can someone please help?
This is my code: https://codesandbox.io/s/5xoj9zw56l
I followed this code: https://codesandbox.io/s/6jr75xj8y3
javascript reactjs material-ui
add a comment |
Can someone please help?
This is my code: https://codesandbox.io/s/5xoj9zw56l
I followed this code: https://codesandbox.io/s/6jr75xj8y3
javascript reactjs material-ui
Please add essential parts here
– Just code
Nov 22 at 12:38
add a comment |
Can someone please help?
This is my code: https://codesandbox.io/s/5xoj9zw56l
I followed this code: https://codesandbox.io/s/6jr75xj8y3
javascript reactjs material-ui
Can someone please help?
This is my code: https://codesandbox.io/s/5xoj9zw56l
I followed this code: https://codesandbox.io/s/6jr75xj8y3
javascript reactjs material-ui
javascript reactjs material-ui
asked Nov 22 at 12:36
aye2m
9117
9117
Please add essential parts here
– Just code
Nov 22 at 12:38
add a comment |
Please add essential parts here
– Just code
Nov 22 at 12:38
Please add essential parts here
– Just code
Nov 22 at 12:38
Please add essential parts here
– Just code
Nov 22 at 12:38
add a comment |
1 Answer
1
active
oldest
votes
Drawer creates an elements, it will have structure like this
parent div > nested div > your data
And while getting the ref into drawer you do not get that div reference which you need to scroll.
What you need to do is you can add ref to your data div
and go through ref.parent
this way you will have parent div ref and there you can scroll the element.
To scroll you must have ref of div where you applied the overflow.
Here is the changes you need to do
Instead of container you will get aprent element
handleScrollTo = () => {
console.log(this.container.parentElement.scrollTop);
this.container.parentElement.scrollTop = 200;
};
instead of using ref on drawer using the data on scroll
<Drawer open={this.state.left} onClose={this.toggleDrawer( "left", false)} onScroll={e=> console.log("scroll " + e.target.scrollTop)} >
<div ref={el=> (this.container = el)} tabIndex={1} role="button" onKeyDown={this.toggleDrawer("left", false)} > {sideList} </div>
</Drawer>
Here is demo link
Your technique works great! Thanks so much. How do I make it auto scroll when the Drawer is open? This code doesn't work:<Drawer onOpen={() => { this.handleScrollTo(); }}>
– aye2m
Nov 22 at 14:54
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53431194%2fhow-to-programmatically-scroll-drawer-in-material-ui-react-js%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
Drawer creates an elements, it will have structure like this
parent div > nested div > your data
And while getting the ref into drawer you do not get that div reference which you need to scroll.
What you need to do is you can add ref to your data div
and go through ref.parent
this way you will have parent div ref and there you can scroll the element.
To scroll you must have ref of div where you applied the overflow.
Here is the changes you need to do
Instead of container you will get aprent element
handleScrollTo = () => {
console.log(this.container.parentElement.scrollTop);
this.container.parentElement.scrollTop = 200;
};
instead of using ref on drawer using the data on scroll
<Drawer open={this.state.left} onClose={this.toggleDrawer( "left", false)} onScroll={e=> console.log("scroll " + e.target.scrollTop)} >
<div ref={el=> (this.container = el)} tabIndex={1} role="button" onKeyDown={this.toggleDrawer("left", false)} > {sideList} </div>
</Drawer>
Here is demo link
Your technique works great! Thanks so much. How do I make it auto scroll when the Drawer is open? This code doesn't work:<Drawer onOpen={() => { this.handleScrollTo(); }}>
– aye2m
Nov 22 at 14:54
add a comment |
Drawer creates an elements, it will have structure like this
parent div > nested div > your data
And while getting the ref into drawer you do not get that div reference which you need to scroll.
What you need to do is you can add ref to your data div
and go through ref.parent
this way you will have parent div ref and there you can scroll the element.
To scroll you must have ref of div where you applied the overflow.
Here is the changes you need to do
Instead of container you will get aprent element
handleScrollTo = () => {
console.log(this.container.parentElement.scrollTop);
this.container.parentElement.scrollTop = 200;
};
instead of using ref on drawer using the data on scroll
<Drawer open={this.state.left} onClose={this.toggleDrawer( "left", false)} onScroll={e=> console.log("scroll " + e.target.scrollTop)} >
<div ref={el=> (this.container = el)} tabIndex={1} role="button" onKeyDown={this.toggleDrawer("left", false)} > {sideList} </div>
</Drawer>
Here is demo link
Your technique works great! Thanks so much. How do I make it auto scroll when the Drawer is open? This code doesn't work:<Drawer onOpen={() => { this.handleScrollTo(); }}>
– aye2m
Nov 22 at 14:54
add a comment |
Drawer creates an elements, it will have structure like this
parent div > nested div > your data
And while getting the ref into drawer you do not get that div reference which you need to scroll.
What you need to do is you can add ref to your data div
and go through ref.parent
this way you will have parent div ref and there you can scroll the element.
To scroll you must have ref of div where you applied the overflow.
Here is the changes you need to do
Instead of container you will get aprent element
handleScrollTo = () => {
console.log(this.container.parentElement.scrollTop);
this.container.parentElement.scrollTop = 200;
};
instead of using ref on drawer using the data on scroll
<Drawer open={this.state.left} onClose={this.toggleDrawer( "left", false)} onScroll={e=> console.log("scroll " + e.target.scrollTop)} >
<div ref={el=> (this.container = el)} tabIndex={1} role="button" onKeyDown={this.toggleDrawer("left", false)} > {sideList} </div>
</Drawer>
Here is demo link
Drawer creates an elements, it will have structure like this
parent div > nested div > your data
And while getting the ref into drawer you do not get that div reference which you need to scroll.
What you need to do is you can add ref to your data div
and go through ref.parent
this way you will have parent div ref and there you can scroll the element.
To scroll you must have ref of div where you applied the overflow.
Here is the changes you need to do
Instead of container you will get aprent element
handleScrollTo = () => {
console.log(this.container.parentElement.scrollTop);
this.container.parentElement.scrollTop = 200;
};
instead of using ref on drawer using the data on scroll
<Drawer open={this.state.left} onClose={this.toggleDrawer( "left", false)} onScroll={e=> console.log("scroll " + e.target.scrollTop)} >
<div ref={el=> (this.container = el)} tabIndex={1} role="button" onKeyDown={this.toggleDrawer("left", false)} > {sideList} </div>
</Drawer>
Here is demo link
answered Nov 22 at 12:58
Just code
8,23142966
8,23142966
Your technique works great! Thanks so much. How do I make it auto scroll when the Drawer is open? This code doesn't work:<Drawer onOpen={() => { this.handleScrollTo(); }}>
– aye2m
Nov 22 at 14:54
add a comment |
Your technique works great! Thanks so much. How do I make it auto scroll when the Drawer is open? This code doesn't work:<Drawer onOpen={() => { this.handleScrollTo(); }}>
– aye2m
Nov 22 at 14:54
Your technique works great! Thanks so much. How do I make it auto scroll when the Drawer is open? This code doesn't work:
<Drawer onOpen={() => { this.handleScrollTo(); }}>
– aye2m
Nov 22 at 14:54
Your technique works great! Thanks so much. How do I make it auto scroll when the Drawer is open? This code doesn't work:
<Drawer onOpen={() => { this.handleScrollTo(); }}>
– aye2m
Nov 22 at 14:54
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53431194%2fhow-to-programmatically-scroll-drawer-in-material-ui-react-js%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Please add essential parts here
– Just code
Nov 22 at 12:38