{"id":38193,"date":"2023-03-09T01:14:46","date_gmt":"2023-07-23T01:37:47","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/"},"modified":"2024-04-29T17:59:22","modified_gmt":"2024-04-29T09:59:22","slug":"%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/","title":{"rendered":"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93)"},"content":{"rendered":"<h2>\u9996\u5148<\/h2>\n<p>\u5982\u6807\u9898\u6240\u8ff0\uff0c\u6211\u4eec\u5c06\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u6211\u4eec\u6ca1\u6709\u4f7f\u7528\u4efb\u4f55\u5e93\uff0c\u800c\u662f\u5229\u7528IntersectionObserver\u6765\u521b\u5efa\u3002<\/p>\n<h2>\u9879\u76ee\u6210\u679c<\/h2>\n<p>&nbsp;<\/p>\n<h3>\u6e90\u4ee3\u7801<\/h3>\n<pre class=\"post-pre\"><code>~\/develop\/HITOTSU\/react_infinity_scroll<span class=\"nv\">$ <\/span>tree <span class=\"nt\">-I<\/span> node_modules \r\n<span class=\"nb\">.<\/span>\r\n\u251c\u2500\u2500 README.md\r\n\u251c\u2500\u2500 package.json\r\n\u251c\u2500\u2500 public\r\n\u2502   \u251c\u2500\u2500 favicon.ico\r\n\u2502   \u251c\u2500\u2500 index.html\r\n\u2502   \u251c\u2500\u2500 logo192.png\r\n\u2502   \u251c\u2500\u2500 logo512.png\r\n\u2502   \u251c\u2500\u2500 manifest.json\r\n\u2502   \u2514\u2500\u2500 robots.txt\r\n\u251c\u2500\u2500 src\r\n\u2502   \u251c\u2500\u2500 App.tsx\r\n\u2502   \u251c\u2500\u2500 hooks\r\n\u2502   \u2502   \u2514\u2500\u2500 useInfinityScroll.tsx\r\n\u2502   \u251c\u2500\u2500 index.tsx\r\n\u2502   \u2514\u2500\u2500 logo.svg\r\n\u251c\u2500\u2500 tsconfig.json\r\n\u2514\u2500\u2500 yarn.lock\r\n\r\n4 directories, 14 files\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"nx\">React<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">ReactDOM<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react-dom\/client<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">App<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.\/App<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">root<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">ReactDOM<\/span><span class=\"p\">.<\/span><span class=\"nf\">createRoot<\/span><span class=\"p\">(<\/span>\r\n  <span class=\"nb\">document<\/span><span class=\"p\">.<\/span><span class=\"nf\">getElementById<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">root<\/span><span class=\"dl\">'<\/span><span class=\"p\">)<\/span> <span class=\"k\">as<\/span> <span class=\"nx\">HTMLElement<\/span>\r\n<span class=\"p\">);<\/span>\r\n<span class=\"nx\">root<\/span><span class=\"p\">.<\/span><span class=\"nf\">render<\/span><span class=\"p\">(<\/span>\r\n  <span class=\"p\">&lt;<\/span><span class=\"nc\">React<\/span><span class=\"p\">.<\/span><span class=\"nc\">StrictMode<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nc\">App<\/span> <span class=\"p\">\/&gt;<\/span>\r\n  <span class=\"p\">&lt;\/<\/span><span class=\"nc\">React<\/span><span class=\"p\">.<\/span><span class=\"nc\">StrictMode<\/span><span class=\"p\">&gt;<\/span>\r\n<span class=\"p\">);<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"nx\">React<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">useRef<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">useInfinityScroll<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.\/hooks\/useInfinityScroll<\/span><span class=\"dl\">'<\/span>\r\n\r\n<span class=\"kd\">function<\/span> <span class=\"nf\">App<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">containerRef<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">useRef<\/span><span class=\"p\">(<\/span><span class=\"kc\">null<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">fetchData<\/span> <span class=\"o\">=<\/span> <span class=\"k\">async <\/span><span class=\"p\">(<\/span><span class=\"nx\">page<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"kd\">const<\/span> <span class=\"nx\">response<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nf\">fetch<\/span><span class=\"p\">(<\/span><span class=\"s2\">`https:\/\/jsonplaceholder.typicode.com\/posts?_page=<\/span><span class=\"p\">${<\/span><span class=\"nx\">page<\/span><span class=\"p\">}<\/span><span class=\"s2\">`<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"kd\">const<\/span> <span class=\"nx\">data<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nx\">response<\/span><span class=\"p\">.<\/span><span class=\"nf\">json<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"nx\">data<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"p\">};<\/span>\r\n\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">data<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Post<\/span><span class=\"p\">[]<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">useInfinityScroll<\/span><span class=\"p\">(<\/span><span class=\"nx\">containerRef<\/span><span class=\"p\">,<\/span> <span class=\"nx\">fetchData<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">style<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">{<\/span><span class=\"na\">height<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">2000px<\/span><span class=\"dl\">'<\/span><span class=\"p\">}<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\u7121\u9650\u30b9\u30af\u30ed\u30fc\u30eb\u958b\u59cb<span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">ref<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">containerRef<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n        <span class=\"si\">{<\/span><span class=\"nx\">data<\/span><span class=\"p\">.<\/span><span class=\"nf\">map<\/span><span class=\"p\">((<\/span><span class=\"nx\">item<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Post<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">(<\/span>\r\n          <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">key<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n            <span class=\"p\">&lt;<\/span><span class=\"nt\">p<\/span><span class=\"p\">&gt;<\/span>\r\n              <span class=\"si\">{<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span><span class=\"si\">}<\/span>\uff1a<span class=\"si\">{<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"si\">}<\/span>\r\n            <span class=\"p\">&lt;\/<\/span><span class=\"nt\">p<\/span><span class=\"p\">&gt;<\/span>\r\n          <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n        <span class=\"p\">))<\/span><span class=\"si\">}<\/span>\r\n      <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">App<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kr\">interface<\/span> <span class=\"nx\">Post<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nl\">userId<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">id<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">title<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">body<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">RefObject<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useCallback<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useEffect<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useState<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">options<\/span> <span class=\"o\">=<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"na\">root<\/span><span class=\"p\">:<\/span> <span class=\"kc\">null<\/span><span class=\"p\">,<\/span> <span class=\"c1\">\/\/ \u30eb\u30fc\u30c8\u8981\u7d20 (viewport) \u3092\u4f7f\u7528<\/span>\r\n    <span class=\"na\">rootMargin<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">0px<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">threshold<\/span><span class=\"p\">:<\/span> <span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"c1\">\/\/ \u8981\u7d20\u304c\u5c11\u3057\u3067\u3082\u30d3\u30e5\u30fc\u30dd\u30fc\u30c8\u306b\u8868\u793a\u3055\u308c\u305f\u77ac\u9593\u304b\u3089\u30b3\u30fc\u30eb\u30d0\u30c3\u30af\u304c\u547c\u3073\u51fa\u3055\u308c\u308b<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"kd\">const<\/span> <span class=\"nx\">useInfinityScroll<\/span> <span class=\"o\">=<\/span> <span class=\"p\">&lt;<\/span><span class=\"nx\">T<\/span><span class=\"p\">,<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"nx\">ref<\/span><span class=\"p\">:<\/span> <span class=\"nx\">RefObject<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">HTMLElement<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">null<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">,<\/span> <span class=\"nx\">fetch<\/span><span class=\"p\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">page<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">T<\/span><span class=\"p\">[]<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">data<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setData<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useState<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">T<\/span><span class=\"p\">[]<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">([]);<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">page<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setPage<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">useState<\/span><span class=\"p\">(<\/span><span class=\"mi\">1<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">isLoading<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setIsLoading<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">useState<\/span><span class=\"p\">(<\/span><span class=\"kc\">false<\/span><span class=\"p\">);<\/span> <span class=\"c1\">\/\/ \u8aad\u307f\u8fbc\u307f\u4e2d\u306e\u30d5\u30e9\u30b0<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">hasMoreData<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setHasMoreData<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">useState<\/span><span class=\"p\">(<\/span><span class=\"kc\">true<\/span><span class=\"p\">);<\/span> <span class=\"c1\">\/\/ \u8ffd\u52a0\u30c7\u30fc\u30bf\u304c\u3042\u308b\u304b\u3069\u3046\u304b\u3092\u8ffd\u8de1<\/span>\r\n\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">scrollObserver<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">useCallback<\/span><span class=\"p\">(<\/span>\r\n    <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nc\">IntersectionObserver<\/span><span class=\"p\">((<\/span><span class=\"nx\">entries<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nf\">log<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">entries<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"nx\">entries<\/span><span class=\"p\">);<\/span>\r\n        <span class=\"nx\">entries<\/span><span class=\"p\">.<\/span><span class=\"nf\">forEach<\/span><span class=\"p\">((<\/span><span class=\"nx\">entry<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n          <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">entry<\/span><span class=\"p\">.<\/span><span class=\"nx\">isIntersecting<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"o\">!<\/span><span class=\"nx\">isLoading<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"nx\">hasMoreData<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"nf\">setIsLoading<\/span><span class=\"p\">(<\/span><span class=\"kc\">true<\/span><span class=\"p\">);<\/span> <span class=\"c1\">\/\/ \u8aad\u307f\u8fbc\u307f\u4e2d\u30d5\u30e9\u30b0\u3092\u8a2d\u5b9a<\/span>\r\n            <span class=\"nf\">fetch<\/span><span class=\"p\">(<\/span><span class=\"nx\">page<\/span><span class=\"p\">).<\/span><span class=\"nf\">then<\/span><span class=\"p\">((<\/span><span class=\"nx\">_data<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n              <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nf\">log<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">fetch call page<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"nx\">page<\/span><span class=\"p\">);<\/span>\r\n              <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">_data<\/span><span class=\"p\">.<\/span><span class=\"nx\">length<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n                <span class=\"nf\">setPage<\/span><span class=\"p\">(<\/span><span class=\"nx\">page<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">1<\/span><span class=\"p\">);<\/span>\r\n                <span class=\"nf\">setData<\/span><span class=\"p\">((<\/span><span class=\"nx\">oldValue<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">[...<\/span><span class=\"nx\">oldValue<\/span><span class=\"p\">,<\/span> <span class=\"p\">...<\/span><span class=\"nx\">_data<\/span><span class=\"p\">]);<\/span>\r\n              <span class=\"p\">}<\/span> <span class=\"k\">else<\/span> <span class=\"p\">{<\/span>\r\n                <span class=\"c1\">\/\/ \u8ffd\u52a0\u30c7\u30fc\u30bf\u304c\u306a\u3044\u5834\u5408<\/span>\r\n                <span class=\"nf\">setHasMoreData<\/span><span class=\"p\">(<\/span><span class=\"kc\">false<\/span><span class=\"p\">);<\/span>\r\n              <span class=\"p\">}<\/span>\r\n              <span class=\"nf\">setIsLoading<\/span><span class=\"p\">(<\/span><span class=\"kc\">false<\/span><span class=\"p\">);<\/span>\r\n            <span class=\"p\">});<\/span>\r\n          <span class=\"p\">}<\/span>\r\n        <span class=\"p\">});<\/span>\r\n      <span class=\"p\">},<\/span><span class=\"nx\">options<\/span><span class=\"p\">),<\/span>\r\n    <span class=\"p\">[<\/span><span class=\"nx\">page<\/span><span class=\"p\">,<\/span> <span class=\"nx\">fetch<\/span><span class=\"p\">,<\/span> <span class=\"nx\">isLoading<\/span><span class=\"p\">,<\/span> <span class=\"nx\">hasMoreData<\/span><span class=\"p\">]<\/span>\r\n  <span class=\"p\">);<\/span>\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"kd\">const<\/span> <span class=\"nx\">target<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">ref<\/span><span class=\"p\">.<\/span><span class=\"nx\">current<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">target<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"kd\">const<\/span> <span class=\"nx\">observer<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">scrollObserver<\/span><span class=\"p\">();<\/span>\r\n      <span class=\"nx\">observer<\/span><span class=\"p\">.<\/span><span class=\"nf\">observe<\/span><span class=\"p\">(<\/span><span class=\"nx\">target<\/span><span class=\"p\">);<\/span>\r\n      <span class=\"k\">return <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nx\">observer<\/span><span class=\"p\">.<\/span><span class=\"nf\">unobserve<\/span><span class=\"p\">(<\/span><span class=\"nx\">target<\/span><span class=\"p\">);<\/span>\r\n      <span class=\"p\">};<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[<\/span><span class=\"nx\">scrollObserver<\/span><span class=\"p\">,<\/span> <span class=\"nx\">ref<\/span><span class=\"p\">]);<\/span>\r\n\r\n  <span class=\"k\">return<\/span> <span class=\"nx\">data<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">};<\/span>\r\n\r\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u9996\u5148 \u5982\u6807\u9898\u6240\u8ff0\uff0c\u6211\u4eec\u5c06\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u6211\u4eec\u6ca1\u6709\u4f7f\u7528\u4efb\u4f55\u5e93\uff0c\u800c\u662f\u5229\u7528IntersectionOb [&hellip;]<\/p>\n","protected":false},"author":10,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-38193","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93) - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93)\" \/>\n<meta property=\"og:description\" content=\"\u9996\u5148 \u5982\u6807\u9898\u6240\u8ff0\uff0c\u6211\u4eec\u5c06\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u6211\u4eec\u6ca1\u6709\u4f7f\u7528\u4efb\u4f55\u5e93\uff0c\u800c\u662f\u5229\u7528IntersectionOb [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-07-23T01:37:47+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T09:59:22+00:00\" \/>\n<meta name=\"author\" content=\"\u5b87, \u534e\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u5b87, \u534e\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/\",\"name\":\"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93) - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-07-23T01:37:47+00:00\",\"dateModified\":\"2024-04-29T09:59:22+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93)\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458\",\"name\":\"\u5b87, \u534e\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g\",\"caption\":\"\u5b87, \u534e\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yuhua\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93) - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93\/","og_locale":"zh_CN","og_type":"article","og_title":"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93)","og_description":"\u9996\u5148 \u5982\u6807\u9898\u6240\u8ff0\uff0c\u6211\u4eec\u5c06\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u6211\u4eec\u6ca1\u6709\u4f7f\u7528\u4efb\u4f55\u5e93\uff0c\u800c\u662f\u5229\u7528IntersectionOb [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-07-23T01:37:47+00:00","article_modified_time":"2024-04-29T09:59:22+00:00","author":"\u5b87, \u534e","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u5b87, \u534e","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"2 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/","name":"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93) - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-07-23T01:37:47+00:00","dateModified":"2024-04-29T09:59:22+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u4f7f\u7528React\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(\u65e0\u9700\u4efb\u4f55\u624b\u518c\u6216\u5e93)"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458","name":"\u5b87, \u534e","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g","caption":"\u5b87, \u534e"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yuhua\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82%e6%97%a0%e9%9c%80%e4%bb%bb%e4%bd%95%e6%89%8b%e5%86%8c%e6%88%96%e5%ba%93\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/38193","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/10"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=38193"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/38193\/revisions"}],"predecessor-version":[{"id":86776,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/38193\/revisions\/86776"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=38193"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=38193"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=38193"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}