Dans cet article, nous abordons un défi courant rencontré lors de la gestion du comportement de défilement dans les applications React : garantir que le focus de défilement reste sur les éléments nouvellement chargés. éléments. Nous présentons différentes approches pour y parvenir, adaptées à React 16.3 et 16.8 .
En utilisant le hook useRef, nous créons une référence pour l'élément souhaité. En appelant la fonction scrollIntoView liée à cette référence, nous faisons défiler en douceur jusqu'à cet élément.
const ScrollDemo = () => { const myRef = useRef(null); const executeScroll = () => myRef.current.scrollIntoView(); // scroll to element return ( <> <div ref={myRef}>Element to scroll to</div> <button onClick={executeScroll}>Click to scroll</button> </> ); };
Pour les composants de classe, nous pouvons créer une référence avec React.createRef (). La méthode executeScroll appelle la fonction scrollIntoView sur la référence pour faire défiler en douceur jusqu'à l'élément souhaité.
class ReadyToScroll extends Component { constructor(props) { super(props); this.myRef = React.createRef(); } render() { return <div ref={this.myRef}>Element to scroll to</div>; } executeScroll = () => this.myRef.current.scrollIntoView(); // scroll to element }
Alternativement, nous pouvons utiliser un rappel de référence pour attacher la référence à un élément . Cette méthode garantit que la référence est affectée directement à l'élément DOM sans créer de variable d'instance.
class ReadyToScroll extends Component { render() { return <div ref={ref => (this.myRef = ref)}>Element to scroll to</div>; } executeScroll = () => this.myRef.scrollIntoView(); // scroll to element }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!