{"id":1375,"date":"2024-06-02T22:28:38","date_gmt":"2024-06-02T22:28:38","guid":{"rendered":""},"modified":"2024-06-05T03:09:46","modified_gmt":"2024-06-04T19:09:46","slug":"javascript%e4%b8%93%e9%a2%98%e4%b9%8b%e6%95%b0%e7%bb%84%e6%89%81%e5%b9%b3%e5%8c%96","status":"publish","type":"post","link":"https:\/\/www.lccc.top\/?p=1375","title":{"rendered":"JavaScript\u4e13\u9898\u4e4b\u6570\u7ec4\u6241\u5e73\u5316"},"content":{"rendered":"<td class=\"d-block comment-body markdown-body  js-comment-body\">\n<h2 dir=\"auto\">\u6241\u5e73\u5316<\/h2>\n<p dir=\"auto\">\u6570\u7ec4\u7684\u6241\u5e73\u5316\uff0c\u5c31\u662f\u5c06\u4e00\u4e2a\u5d4c\u5957\u591a\u5c42\u7684\u6570\u7ec4 array (\u5d4c\u5957\u53ef\u4ee5\u662f\u4efb\u4f55\u5c42\u6570)\u8f6c\u6362\u4e3a\u53ea\u6709\u4e00\u5c42\u7684\u6570\u7ec4\u3002<\/p>\n<p dir=\"auto\">\u4e3e\u4e2a\u4f8b\u5b50\uff0c\u5047\u8bbe\u6709\u4e2a\u540d\u4e3a flatten \u7684\u51fd\u6570\u53ef\u4ee5\u505a\u5230\u6570\u7ec4\u6241\u5e73\u5316\uff0c\u6548\u679c\u5c31\u4f1a\u5982\u4e0b\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"var arr = [1, [2, [3, 4]]];\nconsole.log(flatten(arr)) \/\/ [1, 2, 3, 4]\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-smi\">console<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">log<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-c\">\/\/ [1, 2, 3, 4]<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u77e5\u9053\u4e86\u6548\u679c\u662f\u4ec0\u4e48\u6837\u7684\u4e86\uff0c\u6211\u4eec\u53ef\u4ee5\u53bb\u5c1d\u8bd5\u7740\u5199\u8fd9\u4e2a flatten \u51fd\u6570\u4e86<\/p>\n<h2 dir=\"auto\">\u9012\u5f52<\/h2>\n<p dir=\"auto\">\u6211\u4eec\u6700\u4e00\u5f00\u59cb\u80fd\u60f3\u5230\u7684\u83ab\u8fc7\u4e8e\u5faa\u73af\u6570\u7ec4\u5143\u7d20\uff0c\u5982\u679c\u8fd8\u662f\u4e00\u4e2a\u6570\u7ec4\uff0c\u5c31\u9012\u5f52\u8c03\u7528\u8be5\u65b9\u6cd5\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"\/\/ \u65b9\u6cd5 1\nvar arr = [1, [2, [3, 4]]];\n\nfunction flatten(arr) {\n    var result = [];\n    for (var i = 0, len = arr.length; i &lt; len; i++) {\n        if (Array.isArray(arr[i])) {\n            result = result.concat(flatten(arr[i]))\n        }\n        else {\n            result.push(arr[i])\n        }\n    }\n    return result;\n}\n\n\nconsole.log(flatten(arr))\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-c\">\/\/ \u65b9\u6cd5 1<\/span>\n<span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n\n<span class=\"pl-k\">function<\/span> <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n    <span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">result<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n    <span class=\"pl-k\">for<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">i<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-c1\">0<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">len<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-c1\">length<\/span><span class=\"pl-kos\">;<\/span> <span class=\"pl-s1\">i<\/span> <span class=\"pl-c1\">&lt;<\/span> <span class=\"pl-s1\">len<\/span><span class=\"pl-kos\">;<\/span> <span class=\"pl-s1\">i<\/span><span class=\"pl-c1\">++<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n        <span class=\"pl-k\">if<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-v\">Array<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">isArray<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-s1\">i<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n            <span class=\"pl-s1\">result<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">result<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">concat<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-s1\">i<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span>\n        <span class=\"pl-kos\">}<\/span>\n        <span class=\"pl-k\">else<\/span> <span class=\"pl-kos\">{<\/span>\n            <span class=\"pl-s1\">result<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">push<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-s1\">i<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">)<\/span>\n        <span class=\"pl-kos\">}<\/span>\n    <span class=\"pl-kos\">}<\/span>\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">result<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-kos\">}<\/span>\n\n\n<span class=\"pl-smi\">console<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">log<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><\/pre>\n<\/div>\n<h2 dir=\"auto\">toString<\/h2>\n<p dir=\"auto\">\u5982\u679c\u6570\u7ec4\u7684\u5143\u7d20\u90fd\u662f\u6570\u5b57\uff0c\u90a3\u4e48\u6211\u4eec\u53ef\u4ee5\u8003\u8651\u4f7f\u7528 toString \u65b9\u6cd5\uff0c\u56e0\u4e3a\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content='[1, [2, [3, 4]]].toString() \/\/ \"1,2,3,4\"'>\n<pre class=\"notranslate\"><span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">toString<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-c\">\/\/ \"1,2,3,4\"<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u8c03\u7528 toString \u65b9\u6cd5\uff0c\u8fd4\u56de\u4e86\u4e00\u4e2a\u9017\u53f7\u5206\u9694\u7684\u6241\u5e73\u7684\u5b57\u7b26\u4e32\uff0c\u8fd9\u65f6\u5019\u6211\u4eec\u518d split\uff0c\u7136\u540e\u8f6c\u6210\u6570\u5b57\u4e0d\u5c31\u53ef\u4ee5\u5b9e\u73b0\u6241\u5e73\u5316\u4e86\u5417\uff1f<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"\/\/ \u65b9\u6cd52\nvar arr = [1, [2, [3, 4]]];\n\nfunction flatten(arr) {\n    return arr.toString().split(',').map(function(item){\n        return +item\n    })\n}\n\nconsole.log(flatten(arr))\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-c\">\/\/ \u65b9\u6cd52<\/span>\n<span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n\n<span class=\"pl-k\">function<\/span> <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">toString<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">split<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s\">','<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">map<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-k\">function<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">item<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">{<\/span>\n        <span class=\"pl-k\">return<\/span> <span class=\"pl-c1\">+<\/span><span class=\"pl-s1\">item<\/span>\n    <span class=\"pl-kos\">}<\/span><span class=\"pl-kos\">)<\/span>\n<span class=\"pl-kos\">}<\/span>\n\n<span class=\"pl-smi\">console<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">log<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u7136\u800c\u8fd9\u79cd\u65b9\u6cd5\u4f7f\u7528\u7684\u573a\u666f\u5374\u975e\u5e38\u6709\u9650\uff0c\u5982\u679c\u6570\u7ec4\u662f [1, &#8216;1&#8217;, 2, &#8216;2&#8217;] \u7684\u8bdd\uff0c\u8fd9\u79cd\u65b9\u6cd5\u5c31\u4f1a\u4ea7\u751f\u9519\u8bef\u7684\u7ed3\u679c\u3002<\/p>\n<h2 dir=\"auto\">reduce<\/h2>\n<p dir=\"auto\">\u65e2\u7136\u662f\u5bf9\u6570\u7ec4\u8fdb\u884c\u5904\u7406\uff0c\u6700\u7ec8\u8fd4\u56de\u4e00\u4e2a\u503c\uff0c\u6211\u4eec\u5c31\u53ef\u4ee5\u8003\u8651\u4f7f\u7528 reduce \u6765\u7b80\u5316\u4ee3\u7801\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"\/\/ \u65b9\u6cd53\nvar arr = [1, [2, [3, 4]]];\n\nfunction flatten(arr) {\n    return arr.reduce(function(prev, next){\n        return prev.concat(Array.isArray(next) ? flatten(next) : next)\n    }, [])\n}\n\nconsole.log(flatten(arr))\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-c\">\/\/ \u65b9\u6cd53<\/span>\n<span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n\n<span class=\"pl-k\">function<\/span> <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">reduce<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-k\">function<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">prev<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">next<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">{<\/span>\n        <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">prev<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">concat<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-v\">Array<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">isArray<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">next<\/span><span class=\"pl-kos\">)<\/span> ? <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">next<\/span><span class=\"pl-kos\">)<\/span> : <span class=\"pl-s1\">next<\/span><span class=\"pl-kos\">)<\/span>\n    <span class=\"pl-kos\">}<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">)<\/span>\n<span class=\"pl-kos\">}<\/span>\n\n<span class=\"pl-smi\">console<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">log<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><\/pre>\n<\/div>\n<h2 dir=\"auto\">&#8230;<\/h2>\n<p dir=\"auto\">ES6 \u589e\u52a0\u4e86\u6269\u5c55\u8fd0\u7b97\u7b26\uff0c\u7528\u4e8e\u53d6\u51fa\u53c2\u6570\u5bf9\u8c61\u7684\u6240\u6709\u53ef\u904d\u5386\u5c5e\u6027\uff0c\u62f7\u8d1d\u5230\u5f53\u524d\u5bf9\u8c61\u4e4b\u4e2d\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"var arr = [1, [2, [3, 4]]];\nconsole.log([].concat(...arr)); \/\/ [1, 2, [3, 4]]\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-smi\">console<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">log<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">concat<\/span><span class=\"pl-kos\">(<\/span>...<span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span> <span class=\"pl-c\">\/\/ [1, 2, [3, 4]]<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u6211\u4eec\u7528\u8fd9\u79cd\u65b9\u6cd5\u53ea\u53ef\u4ee5\u6241\u5e73\u4e00\u5c42\uff0c\u4f46\u662f\u987a\u7740\u8fd9\u4e2a\u65b9\u6cd5\u4e00\u76f4\u601d\u8003\uff0c\u6211\u4eec\u53ef\u4ee5\u5199\u51fa\u8fd9\u6837\u7684\u65b9\u6cd5\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"\/\/ \u65b9\u6cd54\nvar arr = [1, [2, [3, 4]]];\n\nfunction flatten(arr) {\n\n    while (arr.some(item =&gt; Array.isArray(item))) {\n        arr = [].concat(...arr);\n    }\n\n    return arr;\n}\n\nconsole.log(flatten(arr))\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-c\">\/\/ \u65b9\u6cd54<\/span>\n<span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n\n<span class=\"pl-k\">function<\/span> <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n\n    <span class=\"pl-k\">while<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">some<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">item<\/span> <span class=\"pl-c1\">=&gt;<\/span> <span class=\"pl-v\">Array<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">isArray<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">item<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n        <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">concat<\/span><span class=\"pl-kos\">(<\/span>...<span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n    <span class=\"pl-kos\">}<\/span>\n\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-kos\">}<\/span>\n\n<span class=\"pl-smi\">console<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">log<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><\/pre>\n<\/div>\n<h2 dir=\"auto\">undercore<\/h2>\n<p dir=\"auto\">\u90a3\u4e48\u5982\u4f55\u5199\u4e00\u4e2a\u62bd\u8c61\u7684\u6241\u5e73\u51fd\u6570\uff0c\u6765\u65b9\u4fbf\u6211\u4eec\u7684\u5f00\u53d1\u5462\uff0c\u6240\u6709\u53c8\u5230\u4e86\u6211\u4eec\u6284\u88ad underscore \u7684\u65f6\u5019\u4e86~<\/p>\n<p dir=\"auto\">\u5728\u8fd9\u91cc\u76f4\u63a5\u7ed9\u51fa\u6e90\u7801\u548c\u6ce8\u91ca\uff0c\u4f46\u662f\u8981\u6ce8\u610f\uff0c\u8fd9\u91cc\u7684 flatten \u51fd\u6570\u5e76\u4e0d\u662f\u6700\u7ec8\u7684 _.flatten\uff0c\u4e3a\u4e86\u65b9\u4fbf\u591a\u4e2a API \u8fdb\u884c\u8c03\u7528\uff0c\u8fd9\u91cc\u5bf9\u6241\u5e73\u8fdb\u884c\u4e86\u66f4\u591a\u7684\u914d\u7f6e\u3002<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"\/**\n * \u6570\u7ec4\u6241\u5e73\u5316\n * @param  {Array} input   \u8981\u5904\u7406\u7684\u6570\u7ec4\n * @param  {boolean} shallow \u662f\u5426\u53ea\u6241\u5e73\u4e00\u5c42\n * @param  {boolean} strict  \u662f\u5426\u4e25\u683c\u5904\u7406\u5143\u7d20\uff0c\u4e0b\u9762\u6709\u89e3\u91ca\n * @param  {Array} output  \u8fd9\u662f\u4e3a\u4e86\u65b9\u4fbf\u9012\u5f52\u800c\u4f20\u9012\u7684\u53c2\u6570\n * \u6e90\u7801\u5730\u5740\uff1ahttps:\/\/github.com\/jashkenas\/underscore\/blob\/master\/underscore.js#L528\n *\/\nfunction flatten(input, shallow, strict, output) {\n\n    \/\/ \u9012\u5f52\u4f7f\u7528\u7684\u65f6\u5019\u4f1a\u7528\u5230output\n    output = output || [];\n    var idx = output.length;\n\n    for (var i = 0, len = input.length; i &lt; len; i++) {\n\n        var value = input[i];\n        \/\/ \u5982\u679c\u662f\u6570\u7ec4\uff0c\u5c31\u8fdb\u884c\u5904\u7406\n        if (Array.isArray(value)) {\n            \/\/ \u5982\u679c\u662f\u53ea\u6241\u5e73\u4e00\u5c42\uff0c\u904d\u5386\u8be5\u6570\u7ec4\uff0c\u4f9d\u6b64\u586b\u5165 output\n            if (shallow) {\n                var j = 0, length = value.length;\n                while (j &lt; length) output[idx++] = value[j++];\n            }\n            \/\/ \u5982\u679c\u662f\u5168\u90e8\u6241\u5e73\u5c31\u9012\u5f52\uff0c\u4f20\u5165\u5df2\u7ecf\u5904\u7406\u7684 output\uff0c\u9012\u5f52\u4e2d\u63a5\u7740\u5904\u7406 output\n            else {\n                flatten(value, shallow, strict, output);\n                idx = output.length;\n            }\n        }\n        \/\/ \u4e0d\u662f\u6570\u7ec4\uff0c\u6839\u636e strict \u7684\u503c\u5224\u65ad\u662f\u8df3\u8fc7\u4e0d\u5904\u7406\u8fd8\u662f\u653e\u5165 output\n        else if (!strict){\n            output[idx++] = value;\n        }\n    }\n\n    return output;\n\n}\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-c\">\/**<\/span>\n<span class=\"pl-c\"> * \u6570\u7ec4\u6241\u5e73\u5316<\/span>\n<span class=\"pl-c\"> * @param  {Array} input   \u8981\u5904\u7406\u7684\u6570\u7ec4<\/span>\n<span class=\"pl-c\"> * @param  {boolean} shallow \u662f\u5426\u53ea\u6241\u5e73\u4e00\u5c42<\/span>\n<span class=\"pl-c\"> * @param  {boolean} strict  \u662f\u5426\u4e25\u683c\u5904\u7406\u5143\u7d20\uff0c\u4e0b\u9762\u6709\u89e3\u91ca<\/span>\n<span class=\"pl-c\"> * @param  {Array} output  \u8fd9\u662f\u4e3a\u4e86\u65b9\u4fbf\u9012\u5f52\u800c\u4f20\u9012\u7684\u53c2\u6570<\/span>\n<span class=\"pl-c\"> * \u6e90\u7801\u5730\u5740\uff1ahttps:\/\/github.com\/jashkenas\/underscore\/blob\/master\/underscore.js#L528<\/span>\n<span class=\"pl-c\"> *\/<\/span>\n<span class=\"pl-k\">function<\/span> <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">input<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">shallow<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">strict<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">output<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n\n    <span class=\"pl-c\">\/\/ \u9012\u5f52\u4f7f\u7528\u7684\u65f6\u5019\u4f1a\u7528\u5230output<\/span>\n    <span class=\"pl-s1\">output<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">output<\/span> <span class=\"pl-c1\">||<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n    <span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">idx<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">output<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-c1\">length<\/span><span class=\"pl-kos\">;<\/span>\n\n    <span class=\"pl-k\">for<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">i<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-c1\">0<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">len<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">input<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-c1\">length<\/span><span class=\"pl-kos\">;<\/span> <span class=\"pl-s1\">i<\/span> <span class=\"pl-c1\">&lt;<\/span> <span class=\"pl-s1\">len<\/span><span class=\"pl-kos\">;<\/span> <span class=\"pl-s1\">i<\/span><span class=\"pl-c1\">++<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n\n        <span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">value<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">input<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-s1\">i<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n        <span class=\"pl-c\">\/\/ \u5982\u679c\u662f\u6570\u7ec4\uff0c\u5c31\u8fdb\u884c\u5904\u7406<\/span>\n        <span class=\"pl-k\">if<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-v\">Array<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">isArray<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">value<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n            <span class=\"pl-c\">\/\/ \u5982\u679c\u662f\u53ea\u6241\u5e73\u4e00\u5c42\uff0c\u904d\u5386\u8be5\u6570\u7ec4\uff0c\u4f9d\u6b64\u586b\u5165 output<\/span>\n            <span class=\"pl-k\">if<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">shallow<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n                <span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">j<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-c1\">0<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">length<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">value<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-c1\">length<\/span><span class=\"pl-kos\">;<\/span>\n                <span class=\"pl-k\">while<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">j<\/span> <span class=\"pl-c1\">&lt;<\/span> <span class=\"pl-s1\">length<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-s1\">output<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-s1\">idx<\/span><span class=\"pl-c1\">++<\/span><span class=\"pl-kos\">]<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">value<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-s1\">j<\/span><span class=\"pl-c1\">++<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n            <span class=\"pl-kos\">}<\/span>\n            <span class=\"pl-c\">\/\/ \u5982\u679c\u662f\u5168\u90e8\u6241\u5e73\u5c31\u9012\u5f52\uff0c\u4f20\u5165\u5df2\u7ecf\u5904\u7406\u7684 output\uff0c\u9012\u5f52\u4e2d\u63a5\u7740\u5904\u7406 output<\/span>\n            <span class=\"pl-k\">else<\/span> <span class=\"pl-kos\">{<\/span>\n                <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">value<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">shallow<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">strict<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">output<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n                <span class=\"pl-s1\">idx<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">output<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-c1\">length<\/span><span class=\"pl-kos\">;<\/span>\n            <span class=\"pl-kos\">}<\/span>\n        <span class=\"pl-kos\">}<\/span>\n        <span class=\"pl-c\">\/\/ \u4e0d\u662f\u6570\u7ec4\uff0c\u6839\u636e strict \u7684\u503c\u5224\u65ad\u662f\u8df3\u8fc7\u4e0d\u5904\u7406\u8fd8\u662f\u653e\u5165 output<\/span>\n        <span class=\"pl-k\">else<\/span> <span class=\"pl-k\">if<\/span> <span class=\"pl-kos\">(<\/span><span class=\"pl-c1\">!<\/span><span class=\"pl-s1\">strict<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">{<\/span>\n            <span class=\"pl-s1\">output<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-s1\">idx<\/span><span class=\"pl-c1\">++<\/span><span class=\"pl-kos\">]<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-s1\">value<\/span><span class=\"pl-kos\">;<\/span>\n        <span class=\"pl-kos\">}<\/span>\n    <span class=\"pl-kos\">}<\/span>\n\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">output<\/span><span class=\"pl-kos\">;<\/span>\n\n<span class=\"pl-kos\">}<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u89e3\u91ca\u4e0b strict\uff0c\u5728\u4ee3\u7801\u91cc\u6211\u4eec\u53ef\u4ee5\u770b\u51fa\uff0c\u5f53\u904d\u5386\u6570\u7ec4\u5143\u7d20\u65f6\uff0c\u5982\u679c\u5143\u7d20\u4e0d\u662f\u6570\u7ec4\uff0c\u5c31\u4f1a\u5bf9 strict \u53d6\u53cd\u7684\u7ed3\u679c\u8fdb\u884c\u5224\u65ad\uff0c\u5982\u679c\u8bbe\u7f6e strict \u4e3a true\uff0c\u5c31\u4f1a\u8df3\u8fc7\u4e0d\u8fdb\u884c\u4efb\u4f55\u5904\u7406\uff0c\u8fd9\u610f\u5473\u7740\u53ef\u4ee5\u8fc7\u6ee4\u975e\u6570\u7ec4\u7684\u5143\u7d20\uff0c\u4e3e\u4e2a\u4f8b\u5b50\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"var arr = [1, 2, [3, 4]];\nconsole.log(flatten(arr, true, true)); \/\/ [3, 4]\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-k\">var<\/span> <span class=\"pl-s1\">arr<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-smi\">console<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">log<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">arr<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">true<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">true<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span> <span class=\"pl-c\">\/\/ [3, 4]<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u90a3\u4e48\u8bbe\u7f6e strict \u5230\u5e95\u6709\u4ec0\u4e48\u7528\u5462\uff1f\u4e0d\u6025\uff0c\u6211\u4eec\u5148\u770b\u4e0b shallow \u548c strct \u5404\u79cd\u503c\u5bf9\u5e94\u7684\u7ed3\u679c\uff1a<\/p>\n<ul dir=\"auto\">\n<li>shallow true + strict false \uff1a\u6b63\u5e38\u6241\u5e73\u4e00\u5c42<\/li>\n<li>shallow false + strict false \uff1a\u6b63\u5e38\u6241\u5e73\u6240\u6709\u5c42<\/li>\n<li>shallow true + strict true \uff1a\u53bb\u6389\u975e\u6570\u7ec4\u5143\u7d20<\/li>\n<li>shallow false + strict true \uff1a \u8fd4\u56de\u4e00\u4e2a[]<\/li>\n<\/ul>\n<p dir=\"auto\">\u6211\u4eec\u770b\u770b underscore \u4e2d\u54ea\u4e9b\u65b9\u6cd5\u8c03\u7528\u4e86 flatten \u8fd9\u4e2a\u57fa\u672c\u51fd\u6570\uff1a<\/p>\n<h2 dir=\"auto\">_.flatten<\/h2>\n<p dir=\"auto\">\u9996\u5148\u5c31\u662f _.flatten\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"_.flatten = function(array, shallow) {\n    return flatten(array, shallow, false);\n};\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-s1\">_<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">flatten<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-k\">function<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">array<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">shallow<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">array<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-s1\">shallow<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">false<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-kos\">}<\/span><span class=\"pl-kos\">;<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u5728\u6b63\u5e38\u7684\u6241\u5e73\u4e2d\uff0c\u6211\u4eec\u5e76\u4e0d\u9700\u8981\u53bb\u6389\u975e\u6570\u7ec4\u5143\u7d20\u3002<\/p>\n<h2 dir=\"auto\">_.union<\/h2>\n<p dir=\"auto\">\u63a5\u4e0b\u6765\u662f _.union\uff1a<\/p>\n<p dir=\"auto\">\u8be5\u51fd\u6570\u4f20\u5165\u591a\u4e2a\u6570\u7ec4\uff0c\u7136\u540e\u8fd4\u56de\u4f20\u5165\u7684\u6570\u7ec4\u7684\u5e76\u96c6\uff0c<\/p>\n<p dir=\"auto\">\u4e3e\u4e2a\u4f8b\u5b50\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"_.union([1, 2, 3], [101, 2, 1, 10], [2, 1]);\n=&gt; [1, 2, 3, 101, 10]\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-s1\">_<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">union<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">101<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">10<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-c1\">=&gt;<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">101<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">10<\/span><span class=\"pl-kos\">]<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u5982\u679c\u4f20\u5165\u7684\u53c2\u6570\u5e76\u4e0d\u662f\u6570\u7ec4\uff0c\u5c31\u4f1a\u5c06\u8be5\u53c2\u6570\u8df3\u8fc7\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"_.union([1, 2, 3], [101, 2, 1, 10], 4, 5);\n=&gt; [1, 2, 3, 101, 10]\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-s1\">_<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">union<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">101<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">10<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">5<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-c1\">=&gt;<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">101<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">10<\/span><span class=\"pl-kos\">]<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u4e3a\u4e86\u5b9e\u73b0\u8fd9\u4e2a\u6548\u679c\uff0c\u6211\u4eec\u53ef\u4ee5\u5c06\u4f20\u5165\u7684\u6240\u6709\u6570\u7ec4\u6241\u5e73\u5316\uff0c\u7136\u540e\u53bb\u91cd\uff0c\u56e0\u4e3a\u53ea\u80fd\u4f20\u5165\u6570\u7ec4\uff0c\u8fd9\u65f6\u5019\u6211\u4eec\u76f4\u63a5\u8bbe\u7f6e strict \u4e3a true\uff0c\u5c31\u53ef\u4ee5\u8df3\u8fc7\u4f20\u5165\u7684\u975e\u6570\u7ec4\u7684\u5143\u7d20\u3002<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"\/\/ \u5173\u4e8e unique \u53ef\u4ee5\u67e5\u770b\u300aJavaScript\u4e13\u9898\u4e4b\u6570\u7ec4\u53bb\u91cd\u300b[](https:\/\/github.com\/mqyqingfeng\/Blog\/issues\/27)\nfunction unique(array) {\n   return Array.from(new Set(array));\n}\n\n_.union = function() {\n    return unique(flatten(arguments, true, true));\n}\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-c\">\/\/ \u5173\u4e8e unique \u53ef\u4ee5\u67e5\u770b\u300aJavaScript\u4e13\u9898\u4e4b\u6570\u7ec4\u53bb\u91cd\u300b[](https:\/\/github.com\/mqyqingfeng\/Blog\/issues\/27)<\/span>\n<span class=\"pl-k\">function<\/span> <span class=\"pl-en\">unique<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">array<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n   <span class=\"pl-k\">return<\/span> <span class=\"pl-v\">Array<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">from<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-k\">new<\/span> <span class=\"pl-v\">Set<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">array<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-kos\">}<\/span>\n\n<span class=\"pl-s1\">_<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">union<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-k\">function<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-en\">unique<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-smi\">arguments<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">true<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">true<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-kos\">}<\/span><\/pre>\n<\/div>\n<h2 dir=\"auto\">_.difference<\/h2>\n<p dir=\"auto\">\u662f\u4e0d\u662f\u611f\u89c9\u6298\u817e strict \u6709\u70b9\u7528\u5904\u4e86\uff0c\u6211\u4eec\u518d\u770b\u4e00\u4e2a _.difference\uff1a<\/p>\n<p dir=\"auto\">\u8bed\u6cd5\u4e3a\uff1a<\/p>\n<blockquote>\n<p dir=\"auto\">_.difference(array, *others)<\/p>\n<\/blockquote>\n<p dir=\"auto\">\u6548\u679c\u662f\u53d6\u51fa\u6765\u81ea array \u6570\u7ec4\uff0c\u5e76\u4e14\u4e0d\u5b58\u5728\u4e8e\u591a\u4e2a other \u6570\u7ec4\u7684\u5143\u7d20\u3002\u8ddf _.union \u4e00\u6837\uff0c\u90fd\u4f1a\u6392\u9664\u6389\u4e0d\u662f\u6570\u7ec4\u7684\u5143\u7d20\u3002<\/p>\n<p dir=\"auto\">\u4e3e\u4e2a\u4f8b\u5b50\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"_.difference([1, 2, 3, 4, 5], [5, 2, 10], [4], 3);\n=&gt; [1, 3]\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-s1\">_<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">difference<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">5<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">5<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">2<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">10<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">4<\/span><span class=\"pl-kos\">]<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n<span class=\"pl-c1\">=&gt;<\/span> <span class=\"pl-kos\">[<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">3<\/span><span class=\"pl-kos\">]<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u5b9e\u73b0\u65b9\u6cd5\u4e5f\u5f88\u7b80\u5355\uff0c\u6241\u5e73 others \u7684\u6570\u7ec4\uff0c\u7b5b\u9009\u51fa array \u4e2d\u4e0d\u5728\u6241\u5e73\u5316\u6570\u7ec4\u4e2d\u7684\u503c\uff1a<\/p>\n<div class=\"highlight highlight-source-js notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"function difference(array, ...rest) {\n\n    rest = flatten(rest, true, true);\n\n    return array.filter(function(item){\n        return rest.indexOf(item) === -1;\n    })\n}\"><\/p>\n<pre class=\"notranslate\"><span class=\"pl-k\">function<\/span> <span class=\"pl-en\">difference<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">array<\/span><span class=\"pl-kos\">,<\/span> ...<span class=\"pl-s1\">rest<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-kos\">{<\/span>\n\n    <span class=\"pl-s1\">rest<\/span> <span class=\"pl-c1\">=<\/span> <span class=\"pl-en\">flatten<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">rest<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">true<\/span><span class=\"pl-kos\">,<\/span> <span class=\"pl-c1\">true<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">;<\/span>\n\n    <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">array<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">filter<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-k\">function<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">item<\/span><span class=\"pl-kos\">)<\/span><span class=\"pl-kos\">{<\/span>\n        <span class=\"pl-k\">return<\/span> <span class=\"pl-s1\">rest<\/span><span class=\"pl-kos\">.<\/span><span class=\"pl-en\">indexOf<\/span><span class=\"pl-kos\">(<\/span><span class=\"pl-s1\">item<\/span><span class=\"pl-kos\">)<\/span> <span class=\"pl-c1\">===<\/span> <span class=\"pl-c1\">-<\/span><span class=\"pl-c1\">1<\/span><span class=\"pl-kos\">;<\/span>\n    <span class=\"pl-kos\">}<\/span><span class=\"pl-kos\">)<\/span>\n<span class=\"pl-kos\">}<\/span><\/pre>\n<\/div>\n<p dir=\"auto\">\u6ce8\u610f\uff0c\u4ee5\u4e0a\u5b9e\u73b0\u7684\u7ec6\u8282\u5e76\u4e0d\u662f\u5b8c\u5168\u6309\u7167 underscore\uff0c\u5177\u4f53\u7ec6\u8282\u7684\u5b9e\u73b0\u611f\u5174\u8da3\u53ef\u4ee5<a href=\"https:\/\/github.com\/jashkenas\/underscore\/blob\/master\/underscore.js#L528\">\u67e5\u770b\u6e90\u7801<\/a>\u3002<\/p>\n<h2 dir=\"auto\">\u4e13\u9898\u7cfb\u5217<\/h2>\n<p dir=\"auto\">JavaScript\u4e13\u9898\u7cfb\u5217\u76ee\u5f55\u5730\u5740\uff1a<a href=\"https:\/\/github.com\/mqyqingfeng\/Blog\">https:\/\/github.com\/mqyqingfeng\/Blog<\/a>\u3002<\/p>\n<p dir=\"auto\">JavaScript\u4e13\u9898\u7cfb\u5217\u9884\u8ba1\u5199\u4e8c\u5341\u7bc7\u5de6\u53f3\uff0c\u4e3b\u8981\u7814\u7a76\u65e5\u5e38\u5f00\u53d1\u4e2d\u4e00\u4e9b\u529f\u80fd\u70b9\u7684\u5b9e\u73b0\uff0c\u6bd4\u5982\u9632\u6296\u3001\u8282\u6d41\u3001\u53bb\u91cd\u3001\u7c7b\u578b\u5224\u65ad\u3001\u62f7\u8d1d\u3001\u6700\u503c\u3001\u6241\u5e73\u3001\u67ef\u91cc\u3001\u9012\u5f52\u3001\u4e71\u5e8f\u3001\u6392\u5e8f\u7b49\uff0c\u7279\u70b9\u662f\u7814(chao)\u7a76(xi) underscore \u548c jQuery \u7684\u5b9e\u73b0\u65b9\u5f0f\u3002<\/p>\n<\/td>\n<p>\u6587\u7ae0\u8f6c\u8f7d\u81ea<a href='https:\/\/github.com\/mqyqingfeng\/Blog\/issues\/36'>https:\/\/github.com\/mqyqingfeng\/Blog\/issues\/36<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6241\u5e73\u5316 \u6570\u7ec4\u7684\u6241\u5e73\u5316\uff0c\u5c31\u662f\u5c06\u4e00\u4e2a\u5d4c\u5957\u591a\u5c42\u7684\u6570\u7ec4 array (\u5d4c\u5957\u53ef\u4ee5\u662f\u4efb\u4f55\u5c42\u6570)\u8f6c\u6362\u4e3a\u53ea\u6709\u4e00\u5c42\u7684\u6570\u7ec4\u3002 \u4e3e\u4e2a\u4f8b\u5b50\uff0c\u5047\u8bbe\u6709\u4e2a\u540d\u4e3a flatten \u7684\u51fd\u6570\u53ef\u4ee5\u505a\u5230&#8230;<\/p>\n<p class=\"read-more\"><a class=\"btn btn-default\" href=\"https:\/\/www.lccc.top\/?p=1375\"> Read More<span class=\"screen-reader-text\">  Read More<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-1375","post","type-post","status-publish","format-standard","hentry","category-learn"],"_links":{"self":[{"href":"https:\/\/www.lccc.top\/index.php?rest_route=\/wp\/v2\/posts\/1375"}],"collection":[{"href":"https:\/\/www.lccc.top\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.lccc.top\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.lccc.top\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.lccc.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1375"}],"version-history":[{"count":1,"href":"https:\/\/www.lccc.top\/index.php?rest_route=\/wp\/v2\/posts\/1375\/revisions"}],"predecessor-version":[{"id":1466,"href":"https:\/\/www.lccc.top\/index.php?rest_route=\/wp\/v2\/posts\/1375\/revisions\/1466"}],"wp:attachment":[{"href":"https:\/\/www.lccc.top\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1375"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.lccc.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1375"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.lccc.top\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1375"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}