{"id":23830,"date":"2024-11-21T16:23:12","date_gmt":"2024-11-21T08:23:12","guid":{"rendered":"https:\/\/fwq.ai\/blog\/23830\/"},"modified":"2024-11-21T16:23:12","modified_gmt":"2024-11-21T08:23:12","slug":"%e5%a6%82%e4%bd%95%e4%bd%bf%e7%94%a8thinkphp6%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/23830\/","title":{"rendered":"\u5982\u4f55\u4f7f\u7528ThinkPHP6\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8"},"content":{"rendered":"<p>\u968f\u7740\u4e92\u8054\u7f51\u7684\u4e0d\u65ad\u53d1\u5c55\uff0c\u65e0\u9650\u6eda\u52a8\u5df2\u6210\u4e3a\u73b0\u4ee3\u7f51\u9875\u8bbe\u8ba1\u7684\u4e00\u79cd\u91cd\u8981\u5143\u7d20\u3002\u65e0\u9650\u6eda\u52a8\u6548\u679c\u53ef\u4ee5\u5e2e\u52a9\u63d0\u9ad8\u7528\u6237\u4f53\u9a8c\uff0c\u8ba9\u7528\u6237\u53ef\u4ee5\u66f4\u8f7b\u677e\u5730\u83b7\u53d6\u4fe1\u606f\uff0c\u63d0\u9ad8\u7528\u6237\u7c98\u6027\u3002\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u75286\u6846\u67b6\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u6548\u679c\u3002<\/p>\n<ol>\n<li>\u5f15\u5165jQuery\u6846\u67b6<\/li>\n<\/ol>\n<p>\u5728\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u4e4b\u524d\uff0c\u9996\u5148\u9700\u8981\u5f15\u5165jQuery\u6846\u67b6\u3002\u53ef\u4ee5\u4f7f\u7528CDN\u6765\u52a0\u901f\u8bbf\u95ee\u901f\u5ea6\uff0c\u4e5f\u53ef\u4ee5\u5c06jQuery\u4e0b\u8f7d\u5230\u672c\u5730\u4ee5\u83b7\u53d6\u66f4\u7a33\u5b9a\u7684\u8bbf\u95ee\u3002<\/p>\n<ol>\n<li>\u6784\u5efa\u57fa\u672c\u7684HTML\u6a21\u677f<\/li>\n<\/ol>\n<p>\u5728HTML\u4e2d\uff0c\u9700\u8981\u6309\u7167\u4ee5\u4e0b\u7ed3\u6784\u6765\u5b9a\u4e49\u5217\u8868\u7684\u6a21\u677f\uff1a<\/p>\n<pre>&lt;div id=\"infinite-scroll\"&gt;\n    &lt;ul id=\"list\"&gt;\n&lt;li&gt;\u7b2c\u4e00\u6761\u6570\u636e&lt;\/li&gt;\n        &lt;li&gt;\u7b2c\u4e8c\u6761\u6570\u636e&lt;\/li&gt;\n        &lt;li&gt;\u7b2c\u4e09\u6761\u6570\u636e&lt;\/li&gt;\n        ...\n    &lt;\/ul&gt;\n&lt;div id=\"loading\"&gt;Loading...&lt;\/div&gt;\n&lt;\/div&gt;<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u5176\u4e2d\uff0c#infinite-scroll\u662f\u4e00\u4e2a\u5927\u5bb9\u5668\uff0c\u7528\u4e8e\u5305\u88f9\u6574\u4e2a\u5217\u8868\u3002#list\u662f\u7528\u4e8e\u663e\u793a\u6570\u636e\u7684\u5bb9\u5668\u3002#loading\u662f\u7528\u4e8e\u663e\u793a\u52a0\u8f7d\u63d0\u793a\u7684\u5bb9\u5668\u3002<\/p>\n<ol>\n<li>\u7f16\u5199Ajax\u8bf7\u6c42\u4ee3\u7801<\/li>\n<\/ol>\n<p>\u5728\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u4e4b\u524d\uff0c\u9700\u8981\u7f16\u5199Ajax\u8bf7\u6c42\u4ee3\u7801\u3002\u53ef\u4ee5\u4f7f\u7528jQuery\u7684$.ajax()\u65b9\u6cd5\u6765\u5b9e\u73b0\uff1a<\/p>\n<p><span>\u7acb\u5373\u5b66\u4e60<\/span>\u201c\u201d\uff1b<\/p>\n<pre>$.ajax({\n    url: \"\/path\/to\/server\", \/\/ \u8bf7\u6c42\u7684\u670d\u52a1\u5668\u5730\u5740\n    type: \"POST\", \/\/ \u8bf7\u6c42\u65b9\u5f0f\n    data: {'last_id' : last_id}, \/\/ \u6700\u540e\u4e00\u4e2a\u6570\u636e\u7684id\n    dataType: \"json\", \/\/ \u6570\u636e\u7c7b\u578b\n    beforeSend: function () {\n        $(\"#loading\").show(); \/\/ \u663e\u793a\u52a0\u8f7d\u63d0\u793a\n    },\n    success: function (data) {\n        if(data.status == 200){\n            \/\/ \u6210\u529f\u83b7\u53d6\u6570\u636e\n            var html = \"\";\n            $(data.data).each(function (index, item) {\n                html += '<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<li>&#8216; + item.title + &#8216;<\/li>\n<p>&#8216;; }); $(&#8220;#list&#8221;).append(html); \/\/ \u5c06\u83b7\u53d6\u7684\u6570\u636e\u8ffd\u52a0\u5230\u5217\u8868\u4e2d last_id = data.last_id; \/\/ \u66f4\u65b0\u6700\u540e\u4e00\u6761\u6570\u636e\u7684id } else { \/\/ \u6570\u636e\u83b7\u53d6\u5931\u8d25 alert(data.message); } }, complete: function () { $(&#8220;#loading&#8221;).hide(); \/\/ \u9690\u85cf\u52a0\u8f7d\u63d0\u793a }, error: function () { alert(&#8220;\u6570\u636e\u83b7\u53d6\u5931\u8d25\uff0c\u8bf7\u7a0d\u540e\u91cd\u8bd5&#8221;); } }); <\/p>\n<p>\u5728\u8bf7\u6c42\u6210\u529f\u540e\uff0c\u5c06\u8fd4\u56deJSON\u683c\u5f0f\u7684\u6570\u636e\u3002\u53ef\u4ee5\u901a\u8fc7$(data.data)\u6765\u83b7\u53d6\u8fd4\u56de\u7684\u6570\u636e\uff0c\u7136\u540e\u5c06\u5176\u8ffd\u52a0\u5230\u6570\u636e\u5bb9\u5668\u4e2d\u3002<\/p>\n<ol>\n<li>\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u6548\u679c<\/li>\n<\/ol>\n<p>\u5f53\u7528\u6237\u6eda\u52a8\u5230\u5217\u8868\u5e95\u90e8\u65f6\uff0c\u5c31\u4f1a\u89e6\u53d1\u8bf7\u6c42\u6570\u636e\u7684Ajax\u8bf7\u6c42\u3002\u53ef\u4ee5\u901a\u8fc7$(window).scroll()\u65b9\u6cd5\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u7684\u6548\u679c\uff1a<\/p>\n<pre>$(window).scroll(function () {\n    if ($(document).scrollTop() + $(window).height() &amp;gt; $(document).height() - 100) {\n        \/\/ \u68c0\u6d4b\u7528\u6237\u6eda\u52a8\u5230\u5e95\u90e8\n        loadMore();\n    }\n});\n\nfunction loadMore() {\n    $.ajax({\n        url: \"\/path\/to\/server\",\n        type: \"POST\",\n        data: {'last_id' : last_id},\n        dataType: \"json\",\n        beforeSend: function () {\n            $(\"#loading\").show(); \/\/ \u663e\u793a\u52a0\u8f7d\u63d0\u793a\n        },\n        success: function (data) {\n            if(data.status == 200){\n                \/\/ \u6210\u529f\u83b7\u53d6\u6570\u636e\n                var html = \"\";\n                $(data.data).each(function (index, item) {\n                    html += '<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<li>&#8216; + item.title + &#8216;<\/li>\n<p>&#8216;; }); $(&#8220;#list&#8221;).append(html); last_id = data.last_id; } else { \/\/ \u6570\u636e\u83b7\u53d6\u5931\u8d25 alert(data.message); } }, complete: function () { $(&#8220;#loading&#8221;).hide(); \/\/ \u9690\u85cf\u52a0\u8f7d\u63d0\u793a }, error: function () { alert(&#8220;\u6570\u636e\u83b7\u53d6\u5931\u8d25\uff0c\u8bf7\u7a0d\u540e\u91cd\u8bd5&#8221;); } }); } <\/p>\n<ol>\n<li>\u4f7f\u7528ThinkPHP6\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u6548\u679c<\/li>\n<\/ol>\n<p>\u5728\u4f7f\u7528ThinkPHP6\u6846\u67b6\u4e2d\uff0c\u9700\u8981\u5b9a\u4e49\u4e00\u4e2a\u63a7\u5236\u5668\u6765\u83b7\u53d6\u6570\u636e\u3002\u53ef\u4ee5\u53c2\u8003\u4ee5\u4e0b\u4ee3\u7801\uff1a<\/p>\n<pre>&lt;?php namespace appcontroller;\n\nuse appBaseController;\nuse appmodelArticle;\n\nclass Index extends BaseController\n{\n    public function index()\n    {\n        $last_id = intval(input('post.last_id', 0));\n        $articles = Article::where('id', '&gt;', $last_id)-&amp;gt;limit(10)-&amp;gt;order('id', 'asc')-&amp;gt;select();\n        $data = [];\n        foreach ($articles as $article) {\n            $data[] = [\n                'id' =&amp;gt; $article-&amp;gt;id,\n                'title' =&amp;gt; $article-&amp;gt;title\n            ];\n        }\n        return json(['status' =&amp;gt; 200, 'data' =&amp;gt; $data, 'last_id' =&amp;gt; $articles-&amp;gt;isEmpty() ? $last_id : $articles-&amp;gt;last()-&amp;gt;getId()]);\n    }\n}<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u5728\u5b9a\u4e49\u63a7\u5236\u5668\u65f6\uff0c\u9996\u5148\u8981\u5f15\u5165\u76f8\u5e94\u7684Model\uff0c\u7136\u540e\u901a\u8fc7Model\u6765\u83b7\u53d6\u6570\u636e\u5e93\u4e2d\u7684\u6570\u636e\u3002\u5728\u83b7\u53d6\u5b8c\u6570\u636e\u540e\uff0c\u9700\u8981\u5c06\u6570\u636e\u683c\u5f0f\u5316\u4e3aJSON\u683c\u5f0f\uff0c\u7136\u540e\u8fd4\u56de\u7ed9\u524d\u7aef\u3002<\/p>\n<ol>\n<li>\u603b\u7ed3<\/li>\n<\/ol>\n<p>\u901a\u8fc7\u4f7f\u7528ThinkPHP6\u6846\u67b6\u548cjQuery\uff0c\u6211\u4eec\u53ef\u4ee5\u5f88\u5bb9\u6613\u5730\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u6548\u679c\u3002\u5982\u679c\u4f60\u7684\u7f51\u7ad9\u9700\u8981\u663e\u793a\u5927\u91cf\u6570\u636e\uff0c\u90a3\u4e48\u65e0\u9650\u6eda\u52a8\u5c31\u662f\u4e00\u4e2a\u5f88\u597d\u7684\u9009\u62e9\uff0c\u5b83\u53ef\u4ee5\u51cf\u5c11\u7528\u6237\u7684\u70b9\u51fb\u64cd\u4f5c\uff0c\u63d0\u9ad8\u7528\u6237\u4f53\u9a8c\uff0c\u589e\u52a0\u7528\u6237\u7559\u5b58\u65f6\u95f4\uff0c\u4fc3\u8fdb\u7f51\u7ad9\u7684\u6d41\u91cf\u589e\u957f\u3002<\/p>\n<p>\u4ee5\u4e0a\u5c31\u662f\u5982\u4f55\u4f7f\u7528ThinkPHP6\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u7684\u8be6\u7ec6\u5185\u5bb9\uff0c\u66f4\u591a\u8bf7\u5173\u6ce8\u7c73\u4e91\u5176\u5b83\u76f8\u5173\u6587\u7ae0\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u968f\u7740\u4e92\u8054\u7f51\u7684\u4e0d\u65ad\u53d1\u5c55\uff0c\u65e0\u9650\u6eda\u52a8\u5df2\u6210\u4e3a\u73b0\u4ee3\u7f51\u9875\u8bbe\u8ba1\u7684\u4e00\u79cd\u91cd\u8981\u5143\u7d20\u3002\u65e0\u9650\u6eda\u52a8\u6548\u679c\u53ef\u4ee5\u5e2e\u52a9\u63d0\u9ad8\u7528\u6237\u4f53\u9a8c\uff0c\u8ba9\u7528\u6237\u53ef\u4ee5\u66f4\u8f7b\u677e\u5730\u83b7\u53d6\u4fe1\u606f\uff0c\u63d0\u9ad8\u7528\u6237\u7c98\u6027\u3002\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u75286\u6846\u67b6\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u6548\u679c\u3002 \u5f15\u5165jQuery\u6846\u67b6 \u5728\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u4e4b\u524d\uff0c\u9996\u5148\u9700\u8981\u5f15\u5165jQuery\u6846\u67b6\u3002\u53ef\u4ee5\u4f7f\u7528CDN\u6765\u52a0\u901f\u8bbf\u95ee\u901f\u5ea6\uff0c\u4e5f\u53ef\u4ee5\u5c06jQuery\u4e0b\u8f7d\u5230\u672c\u5730\u4ee5\u83b7\u53d6\u66f4\u7a33\u5b9a\u7684\u8bbf\u95ee\u3002 \u6784\u5efa\u57fa\u672c\u7684HTML\u6a21\u677f \u5728HTML\u4e2d\uff0c\u9700\u8981\u6309\u7167\u4ee5\u4e0b\u7ed3\u6784\u6765\u5b9a\u4e49\u5217\u8868\u7684\u6a21\u677f\uff1a &lt;div id=&#8221;infinite-scroll&#8221;&gt; &lt;ul id=&#8221;list&#8221;&gt; &lt;li&gt;\u7b2c\u4e00\u6761\u6570\u636e&lt;\/li&gt; &lt;li&gt;\u7b2c\u4e8c\u6761\u6570\u636e&lt;\/li&gt; &lt;li&gt;\u7b2c\u4e09\u6761\u6570\u636e&lt;\/li&gt; &#8230; &lt;\/ul&gt; &lt;div id=&#8221;loading&#8221;&gt;Loading&#8230;&lt;\/div&gt; &lt;\/div&gt; \u767b\u5f55\u540e\u590d\u5236 \u5176\u4e2d\uff0c#infinite-scroll\u662f\u4e00\u4e2a\u5927\u5bb9\u5668\uff0c\u7528\u4e8e\u5305\u88f9\u6574\u4e2a\u5217\u8868\u3002#list\u662f\u7528\u4e8e\u663e\u793a\u6570\u636e\u7684\u5bb9\u5668\u3002#loading\u662f\u7528\u4e8e\u663e\u793a\u52a0\u8f7d\u63d0\u793a\u7684\u5bb9\u5668\u3002 \u7f16\u5199Ajax\u8bf7\u6c42\u4ee3\u7801 \u5728\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u4e4b\u524d\uff0c\u9700\u8981\u7f16\u5199Ajax\u8bf7\u6c42\u4ee3\u7801\u3002\u53ef\u4ee5\u4f7f\u7528jQuery\u7684$.ajax()\u65b9\u6cd5\u6765\u5b9e\u73b0\uff1a \u7acb\u5373\u5b66\u4e60\u201c\u201d\uff1b $.ajax({ url: &#8220;\/path\/to\/server&#8221;, \/\/ \u8bf7\u6c42\u7684\u670d\u52a1\u5668\u5730\u5740 type: &#8220;POST&#8221;, \/\/ \u8bf7\u6c42\u65b9\u5f0f data: {&#8216;last_id&#8217; : last_id}, \/\/ \u6700\u540e\u4e00\u4e2a\u6570\u636e\u7684id dataType: &#8220;json&#8221;, \/\/ \u6570\u636e\u7c7b\u578b beforeSend: function () { $(&#8220;#loading&#8221;).show(); \/\/ \u663e\u793a\u52a0\u8f7d\u63d0\u793a }, success: function (data) { if(data.status == [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[16],"tags":[],"class_list":["post-23830","post","type-post","status-publish","format-standard","hentry","category-16"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/23830","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/comments?post=23830"}],"version-history":[{"count":0,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/23830\/revisions"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=23830"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=23830"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=23830"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}