{"id":5551,"date":"2018-08-03T07:00:44","date_gmt":"2018-08-03T14:00:44","guid":{"rendered":"https:\/\/www.couchbase.com\/blog\/?p=5551"},"modified":"2025-06-13T20:14:57","modified_gmt":"2025-06-14T03:14:57","slug":"developing-a-typeahead-with-couchbase-node-js-and-full-text-search","status":"publish","type":"post","link":"https:\/\/www.couchbase.com\/blog\/ko\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/","title":{"rendered":"\ud0c0\uc785\ud5e4\ub4dc: Couchbase \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9 \ubc0f Node.js\ub85c \uac1c\ubc1c\ud558\uae30"},"content":{"rendered":"<p>\uc9c0\ub09c 1\ub144\uc5ec \ub3d9\uc548 \uc800\ub294 \ub2e4\uc591\ud55c \ud29c\ud1a0\ub9ac\uc5bc\uc744 \uc791\uc131\ud588\uc2b5\ub2c8\ub2e4. <a href=\"https:\/\/www.couchbase.com\/blog\/ko\/products\/full-text-search\/\">\uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9<\/a> (FTS) \uc11c\ube44\uc2a4\ub294 \ub300\ubd80\ubd84 SDK \uc911 \ud558\ub098\ub97c \uc0ac\uc6a9\ud558\uc5ec \ubb34\uc5b8\uac00\ub97c \uc218\ud589\ud558\ub294 \ubc29\ubc95\uc5d0 \ub300\ud55c \uad6c\uccb4\uc801\uc778 \uc608\uc81c\uc774\uba70, \uadf8 \ub4a4\uc5d0 \uc788\ub294 \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uacfc\ub294 \uc804\ud600 \uad00\ub828\uc774 \uc5c6\uc2b5\ub2c8\ub2e4. \uac00\ub2a5\ud55c \ub9ce\uc740 \uc2e4\uc81c \uc560\ud50c\ub9ac\ucf00\uc774\uc158 \uc911 \ud558\ub098\ub294 \uc6f9 \uc560\ud50c\ub9ac\ucf00\uc774\uc158 \uc591\uc2dd\uc5d0\uc11c \ud0c0\uc774\ud504\ud5e4\ub4dc \ub610\ub294 \ub370\uc774\ud130 \uc81c\uc548 \uae30\ub2a5\uc744 \uc0ac\uc6a9\ud558\ub294 \uac83\uc785\ub2c8\ub2e4. \uc0ac\uc6a9\uc790 \uc785\ub825\uc5d0 \ub530\ub77c \uac00\ub2a5\ud55c \uacb0\uacfc\ub97c \uac80\uc0c9\ud558\uc5ec \ud45c\uc2dc\ud569\ub2c8\ub2e4.<\/p>\n<p>\ub2e4\uc74c\uc5d0\uc11c \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9 \uc11c\ube44\uc2a4\ub97c \uc0ac\uc6a9\ud558\uc5ec \ud0c0\uc774\ud3ec\ud5e4\ub4dc \uc591\uc2dd\uc744 \uc791\uc131\ud558\ub294 \ubc29\ubc95\uc744 \uc0b4\ud3b4\ubcf4\uaca0\uc2b5\ub2c8\ub2e4. <a href=\"https:\/\/www.couchbase.com\/blog\/ko\/\" target=\"_blank\" rel=\"noopener noreferrer\">\uce74\uc6b0\uce58\ubca0\uc774\uc2a4<\/a>, Node.js \ubc0f jQuery\ub97c \uc0ac\uc6a9\ud558\uc5ec \ubaa8\ub4e0 \uac83\uc744 \ud558\ub098\ub85c \ubb36\uc2b5\ub2c8\ub2e4.<\/p>\n<p><!--more--><\/p>\n<p>\ub108\ubb34 \uae4a\uc774 \ub4e4\uc5b4\uac00\uae30 \uc804\uc5d0, \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9\uc744 \uc0ac\uc6a9\ud558\ub3c4\ub85d \uc124\uc815\ub41c Couchbase Server 5.0 \uc774\uc0c1\uc744 \uc774\ubbf8 \uc124\uce58 \ubc0f \uad6c\uc131\ud588\ub2e4\ub294 \uac00\uc815\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. API\uac00 Node.js \ubc0f Express Framework\ub85c \uad6c\ub3d9\ub418\ubbc0\ub85c Node.js\ub3c4 \uc774\ubbf8 \uc124\uce58\ub418\uc5b4 \uc788\ub2e4\uace0 \uac00\uc815\ud569\ub2c8\ub2e4.<\/p>\n<h2>FTS \uc778\ub371\uc2a4\ub97c \uc0ac\uc6a9\ud558\uc5ec NoSQL \ub370\uc774\ud130 \uc9d1\ud569 \ub9cc\ub4e4\uae30<\/h2>\n<p>FTS\ub85c \uc791\uc5c5\ud560 \ub54c\ub294 \uc7a0\uc7ac\uc801\uc73c\ub85c \ubb34\uc81c\ud55c\uc758 \uac80\uc0c9 \uc2dc\ub098\ub9ac\uc624 \uc911 \ud558\ub098\ub97c \uc0ac\uc6a9\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc774 \uc608\uc81c\uc5d0\uc11c\ub294 \uc880 \ub354 \uad6c\uccb4\uc801\uc73c\ub85c \uc124\uba85\ud558\uaca0\uc2b5\ub2c8\ub2e4.<\/p>\n<p>\uc74c\uc545 \ub370\uc774\ud130\ub85c \uc791\uc5c5\ud558\uace0 \uc788\uace0 \uc544\ud2f0\uc2a4\ud2b8, \uc568\ubc94 \ub610\ub294 \ub178\ub798 \uc81c\ubaa9\uc744 \uae30\uc900\uc73c\ub85c \ub178\ub798\ub97c \uac80\uc0c9\ud558\ub294 \uac83\uc774 \ubaa9\ud45c\ub77c\uace0 \uac00\uc815\ud574 \ubcf4\uaca0\uc2b5\ub2c8\ub2e4. \uac01 NoSQL \ubb38\uc11c\uac00 \ub2e4\uc74c\uacfc \uac19\uc740 \ud615\uc2dd\uc744 \ucde8\ud55c\ub2e4\uace0 \uac00\uc815\ud574 \ubcf4\uaca0\uc2b5\ub2c8\ub2e4:<\/p>\n<pre class=\"lang:default decode:true\">{\r\n  \"title\": \"Love Story\",\r\n  \"artist\": \"Taylor Swift\",\r\n  \"album\": \"Fearless\",\r\n  \"type\": \"song\"\r\n}<\/pre>\n<p>\uac00\uc7a5 \ubcf5\uc7a1\ud55c JSON \ubb38\uc11c\ub294 \uc544\ub2c8\uc9c0\ub9cc, \uc6b0\ub9ac\uac00 \uc6d0\ud55c\ub2e4\uba74 \uadf8\ub807\uac8c \ub420 \uc218\ub3c4 \uc788\uc2b5\ub2c8\ub2e4. \uc774 \uc608\uc81c\uc5d0\uc11c\ub294 \uc774 \uc608\uc81c\uc5d0\uc11c\ub294 \ub2e8\uc9c0 <code>title<\/code> \ubc0f <code>\uc544\ud2f0\uc2a4\ud2b8<\/code>\ud655\uc7a5\ud558\ub294 \ub370 \ub354 \ub9ce\uc740 \ub178\ub825\uc774 \ud544\uc694\ud558\uc9c0 \uc54a\uc74c\uc5d0\ub3c4 \ubd88\uad6c\ud558\uace0 \ub9d0\uc785\ub2c8\ub2e4.<\/p>\n<p>FTS\ub97c \uc0ac\uc6a9\ud558\ub824\uba74 Couchbase\uc5d0\uc11c \ub2e4\uc74c\uacfc \uac19\uc740 \ud2b9\uc218 \uc778\ub371\uc2a4\ub97c \ub9cc\ub4e4\uc5b4\uc57c \ud569\ub2c8\ub2e4:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone wp-image-5554 size-full\" src=\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/2018\/07\/fts-music-index.png\" alt=\"\" width=\"1500\" height=\"689\" srcset=\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/fts-music-index.png 1500w, https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/fts-music-index-300x138.png 300w, https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/fts-music-index-1024x470.png 1024w, https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/fts-music-index-768x353.png 768w, https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/fts-music-index-20x9.png 20w, https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/fts-music-index-1320x606.png 1320w\" sizes=\"auto, (max-width: 1500px) 100vw, 1500px\" \/><\/p>\n<p>\uc694\uc57d\ud558\uc790\uba74, \uc778\ub371\uc2a4\uc758 \uc774\ub984\uc744 \uc815\ud558\uace0, \uc720\ud615 \ub9e4\ud551\uc744 \uc9c0\uc815\ud558\uace0, \uc778\ub371\uc2f1\ud560 \ud544\ub4dc\ub97c \uc815\uc758\ud574\uc57c \ud558\uba70, \uc774 \ubaa8\ub4e0 \uac83\uc774 \uc778\ub371\uc2a4 \uc790\uccb4\uc5d0 \uc800\uc7a5\ub429\ub2c8\ub2e4.<\/p>\n<p>\uc778\ub371\uc2a4\ub97c \ub9cc\ub4e4 \ub54c \ud544\ub4dc\ub97c \uc800\uc7a5\ud558\ub294 \uac83\uc774 \uc911\uc694\ud569\ub2c8\ub2e4. \uadf8\ub807\uc9c0 \uc54a\uc73c\uba74 \ud0c0\uc774\ud504\ud5e4\ub4dc\uc5d0 \ud45c\uc2dc\ud560 \ub0b4\uc6a9\uc774 \uc5c6\uc2b5\ub2c8\ub2e4.<\/p>\n<h2>\uac80\uc0c9\uc744 \uc704\ud55c Node.js RESTful API \uc5d4\ub4dc\ud3ec\uc778\ud2b8 \uac1c\ubc1c\ud558\uae30<\/h2>\n<p>\uc774\uc81c \ub370\uc774\ud130\ubca0\uc774\uc2a4\uc5d0 \uc77c\ubd80 \ub370\uc774\ud130\uac00 \uc788\uace0 \uac80\uc0c9\uc744 \uc704\ud574 \uc778\ub371\uc2a4\uac00 \uc0dd\uc131\ub418\uc5c8\uc73c\ubbc0\ub85c Node.js\ub85c API \uc5d4\ub4dc\ud3ec\uc778\ud2b8\ub97c \ub9cc\ub4e4 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc774 API\uc758 \ud575\uc2ec\uc740 \uac80\uc0c9 \uc591\uc2dd\uc5d0\uc11c \uc0ac\uc6a9\ud560 \uc5d4\ub4dc\ud3ec\uc778\ud2b8 \uc5ed\ud560\uc744 \ud558\ub294 \uac83\uc785\ub2c8\ub2e4. \uacb0\uad6d, \ud074\ub77c\uc774\uc5b8\ud2b8 \ub300\uba74 \ud504\ub860\ud2b8\uc5d4\ub4dc\uac00 \ub370\uc774\ud130\ubca0\uc774\uc2a4\ub97c \uc9c1\uc811 \uacf5\uaca9\ud558\ub294 \uac83\uc740 \uc548\uc804\ud558\uc9c0 \uc54a\uc73c\ubbc0\ub85c \uc6d0\ud558\uc9c0 \uc54a\uc744 \uac83\uc785\ub2c8\ub2e4.<\/p>\n<p>\ucef4\ud4e8\ud130\uc5d0\uc11c \uc0c8 \ud504\ub85c\uc81d\ud2b8\ub97c \ub9cc\ub4e4\uace0 \uba85\ub839\uc904\uc5d0\uc11c \ub2e4\uc74c\uc744 \uc2e4\ud589\ud569\ub2c8\ub2e4:<\/p>\n<pre class=\"lang:default decode:true\">npm init -y\r\nnpm install couchbase cors express --save<\/pre>\n<p>\uc704\uc758 \uba85\ub839\uc740 \uc0c8\ub85c\uc6b4\u00a0<strong>package.json<\/strong> \ud30c\uc77c\uc744 \uc5f4\uace0 \ud504\ub85c\uc81d\ud2b8\uc758 \uba87 \uac00\uc9c0 \uc885\uc18d\uc131\uc744 \uc124\uce58\ud569\ub2c8\ub2e4. Express \ud504\ub808\uc784\uc6cc\ud06c\uc640 \ud568\uaed8 Couchbase SDK\ub97c \uc0ac\uc6a9\ud558\uba70, \uad50\ucc28 \ucd9c\ucc98 \ub9ac\uc18c\uc2a4 \uacf5\uc720(CORS)\ub97c \ucc98\ub9ac\ud558\uae30 \uc704\ud55c \ud328\ud0a4\uc9c0\ub97c \uc124\uce58\ud569\ub2c8\ub2e4.<\/p>\n<p>\uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc758 \ud06c\uae30\uac00 \uc791\uae30 \ub54c\ubb38\uc5d0\u00a0<strong>app.js<\/strong> \ud30c\uc77c\uc744 \ud504\ub85c\uc81d\ud2b8\uc5d0 \ucd94\uac00\ud558\uc5ec \ubaa8\ub4e0 \ucf54\ub4dc\ub97c \ud3ec\ud568\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \ub2e4\uc74c\uc744 \uc0ac\uc6a9\ud558\uc5ec \ubd80\ud2b8\uc2a4\ud2b8\ub7a9\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4:<\/p>\n<pre class=\"lang:default decode:true\">const Couchbase = require(\"couchbase\");\r\nconst Express = require(\"express\");\r\nconst Cors = require(\"cors\");\r\n\r\nvar app = Express();\r\nvar cluster = new Couchbase.Cluster(\"couchbase:\/\/localhost\");\r\ncluster.authenticate(\"example\", \"123456\");\r\nvar bucket = cluster.openBucket(\"example\");\r\n\r\napp.use(Cors());\r\n\r\napp.get(\"\/search\", (request, response) =&gt; { });\r\n\r\napp.listen(3000, () =&gt; {\r\n    console.log(\"Listening at :3000...\");\r\n});<\/pre>\n<p>\uc704\uc758 \ucf54\ub4dc\uc5d0\uc11c\ub294 \ub2e4\uc6b4\ub85c\ub4dc\ud55c \uc885\uc18d \uc694\uc18c\ub97c \uac00\uc838\uc640\uc11c Express\ub97c \uad6c\uc131\ud558\uace0 Couchbase \uc778\uc2a4\ud134\uc2a4\uc5d0 \uc5f0\uacb0\ud588\uc2b5\ub2c8\ub2e4. \uc5f0\uacb0 \uc815\ubcf4\ub97c \uc2e4\uc81c \ub370\uc774\ud130\ubca0\uc774\uc2a4 \uc778\uc2a4\ud134\uc2a4\uc758 \uc815\ubcf4\ub85c \ubc14\uafd4\uc57c \ud569\ub2c8\ub2e4.<\/p>\n<p>\uadf8\ub9ac\uace0 <code>\/\uac80\uc0c9<\/code> \uc5d4\ub4dc\ud3ec\uc778\ud2b8\ub294 \ubaa8\ub4e0 \ub9c8\ubc95\uc774 \uc77c\uc5b4\ub098\ub294 \uacf3\uc785\ub2c8\ub2e4. \uc790\uc138\ud788 \uc0b4\ud3b4\ubcf4\uaca0\uc2b5\ub2c8\ub2e4:<\/p>\n<pre class=\"lang:default decode:true\">app.get(\"\/search\", (request, response) =&gt; {\r\n    var SearchQuery = Couchbase.SearchQuery;\r\n    var query = SearchQuery.new(\"idx-music\", SearchQuery.match(request.query.query).fuzziness(1));\r\n    query.fields([\"title\", \"artist\"]);\r\n    bucket.query(query, function(error, result, meta) {\r\n        if(error) {\r\n            return response.status(500).send({ message: error.message });\r\n        }\r\n        result = result.map(item =&gt; {\r\n            return {\r\n                id: item.id,\r\n                score: item.score,\r\n                title: item.fields.title,\r\n                artist: item.fields.artist\r\n            };\r\n        });\r\n        response.send(result);\r\n    });\r\n});<\/pre>\n<p>\uba3c\uc800 \ucffc\ub9ac\ub97c \ud2b9\uc815 \uc778\ub371\uc2a4\uc5d0 \ub300\ud55c \uc77c\uce58 \ucffc\ub9ac\ub85c \uc815\uc758\ud569\ub2c8\ub2e4. \uc77c\uce58 \ucffc\ub9ac\ub294 \uc694\uccad\uc758 \ucffc\ub9ac \ub9e4\uac1c\ubcc0\uc218\ub97c \ud1b5\ud574 \uc804\ub2ec\ub41c \ubaa8\ub4e0 \ud14d\uc2a4\ud2b8\ub97c \uc0ac\uc6a9\ud569\ub2c8\ub2e4. \ub610\ud55c \ub2e8\uc5b4\uc758 \ucca0\uc790 \uc624\ub958\ub97c \uc218\uc6a9\ud558\uae30 \uc704\ud574 \uac12\uc774 1\uc778 \ud37c\uc9c0 \uac80\uc0c9\uc744 \uc0ac\uc6a9\ud560 \uac83\uc785\ub2c8\ub2e4.<\/p>\n<p>\ucffc\ub9ac\ub97c \uc2e4\ud589\ud558\uae30 \uc804\uc5d0 \ucffc\ub9ac\ub97c \uc2e4\ud589\ud558\uae30 \uc804\uc5d0 \uc6b0\ub9ac\ub294 <code>title<\/code> \uadf8\ub9ac\uace0 <code>\uc544\ud2f0\uc2a4\ud2b8<\/code> \ub97c \uacb0\uacfc\uc5d0\uc11c \ub2e4\uc2dc \ud074\ub9ad\ud569\ub2c8\ub2e4. \uc774\ub294 \uc778\ub371\uc2a4\uc5d0 \ucd94\uac00\ud55c \uac83\uacfc \ub3d9\uc77c\ud55c \ud544\ub4dc\uc785\ub2c8\ub2e4.<\/p>\n<p>\ucffc\ub9ac\uac00 \uc131\uacf5\uc801\uc73c\ub85c \uc2e4\ud589\ub418\uba74 \uacb0\uacfc\ub97c \uad6c\ubb38 \ubd84\uc11d\ud558\uc5ec \uc751\ub2f5\uacfc \ud568\uaed8 \uc81c\uacf5\ub418\ub294 \ucd94\uac00 \uba54\ud0c0\ub370\uc774\ud130\uac00 \uc544\ub2cc \uc6d0\ud558\ub294 \ud56d\ubaa9\ub9cc \ubc18\ud658\ud569\ub2c8\ub2e4.<\/p>\n<p>cURL \uc694\uccad\uc744 \uc0ac\uc6a9\ud558\uc5ec https:\/\/localhost:3000\/search?query=swift \uc5d0 \uc811\uc18d\ud558\uba74 \ub370\uc774\ud130 \uc9d1\ud569\uc5d0 \ub530\ub77c \ub2e4\uc591\ud55c \uacb0\uacfc\ub97c \ud655\uc778\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n<h2>jQuery \ubc0f Typeahead \ub77c\uc774\ube0c\ub7ec\ub9ac\ub85c \ud504\ub860\ud2b8\uc5d4\ub4dc \ub514\uc790\uc778\ud558\uae30<\/h2>\n<p>cURL\ub85c \uac80\uc0c9\ud558\ub294 \uac83\ub3c4 \ub098\ub984\uc758 \uac00\uce58\uac00 \uc788\uc9c0\ub9cc, \ub300\ubd80\ubd84\uc758 \uacbd\uc6b0 \uc6b0\ub9ac\uac00 \uc6d0\ud558\ub294 \uac83\uc740 \uc544\ub2d9\ub2c8\ub2e4. \ub300\uc2e0 \uc27d\uac8c \uc0ac\uc6a9\ud560 \uc218 \uc788\ub294 \uc6f9 \uae30\uc220\uc744 \uc0ac\uc6a9\ud558\uc5ec \ud074\ub77c\uc774\uc5b8\ud2b8\uc6a9 \ud504\ub7f0\ud2b8\uc5d4\ub4dc\ub97c \ub9cc\ub4e4\uc5b4\uc57c \ud569\ub2c8\ub2e4.<\/p>\n<p>\ub9ce\uc740 \uc7a0\uc7ac\uc801 \ub77c\uc774\ube0c\ub7ec\ub9ac\uac00 \uc788\uc9c0\ub9cc \uc5ec\uae30\uc11c\ub294 <a href=\"https:\/\/twitter.github.io\/typeahead.js\/\" target=\"_blank\" rel=\"noopener noreferrer\">typeahead.js<\/a> \uc5d0\uc11c \uad00\ub9ac\ud569\ub2c8\ub2e4. \ub2e4\uc6b4\ub85c\ub4dc\ud574\uc57c \ud558\uc9c0\ub9cc \uc5ec\uae30\uc11c\ub294 \ub2e4\uc74c \ubc84\uc804\uc744 \uc0ac\uc6a9\ud55c\ub2e4\ub294 \uc810\uc5d0 \uc720\uc758\ud558\uc138\uc694. <a href=\"https:\/\/github.com\/twitter\/typeahead.js\/releases\/tag\/v0.10.5\" target=\"_blank\" rel=\"noopener noreferrer\">0.10.5<\/a> \uc758 \ubc84\uadf8\ub85c \uc778\ud574 \ub77c\uc774\ube0c\ub7ec\ub9ac\uac00 \uc911\ub2e8\ub418\uc5c8\uc2b5\ub2c8\ub2e4. \ub77c\uc774\ube0c\ub7ec\ub9ac \ubb38\uc81c\ub97c \ud574\uacb0\ud558\ub290\ub77c \ud558\ub8e8\uc758 \uc0c1\ub2f9 \uc2dc\uac04\uc744 \ud5c8\ube44\ud558\uace0 \ub098\uc11c\uc57c \uc774 \uc0ac\uc2e4\uc744 \uc54c\uac8c \ub418\uc5c8\uc2b5\ub2c8\ub2e4.<\/p>\n<p>\ub2e4\uc74c \uad6c\uc870\ub97c \ud3ec\ud568\ud558\ub294 \ud504\ub85c\uc81d\ud2b8\ub97c \ub9cc\ub4ed\ub2c8\ub2e4:<\/p>\n<pre class=\"lang:default decode:true\">js\r\n  handlebars-v4.0.11.js\r\n  jquery-3.3.1.min.js\r\n  typeahead.bundle.min.js\r\nindex.html<\/pre>\n<p>\uc608, \ub2e4\uc74c\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. <a href=\"https:\/\/handlebarsjs.com\/\" target=\"_blank\" rel=\"noopener noreferrer\">\ud578\ub4e4\ubc14.js<\/a> \uadf8\ub9ac\uace0 <a href=\"https:\/\/jquery.com\/\" target=\"_blank\" rel=\"noopener noreferrer\">jQuery<\/a> \uc774 \ud504\ub860\ud2b8\uc5d4\ub4dc\ub85c \uc131\uacf5\ud558\uae30 \uc704\ud574. \uc81c\uac00 \uc54c\uae30\ub85c\ub294 \ubc84\uc804\uc740 \uc911\uc694\ud558\uc9c0 \uc54a\uc73c\uba70, \ud0c0\uc774\ud3ec\ud5e4\ub4dc \ub77c\uc774\ube0c\ub7ec\ub9ac\uc758 \ubc84\uc804\ub9cc \uc2e0\uacbd\uc4f0\uba74 \ub429\ub2c8\ub2e4.<\/p>\n<p>\ud504\ub85c\uc81d\ud2b8\uc758\u00a0<strong>index.html<\/strong> \ud30c\uc77c\uc5d0 \ub2e4\uc74c\uc744 \ud3ec\ud568\ud569\ub2c8\ub2e4:<\/p>\n<pre class=\"lang:default decode:true\">&lt;html&gt;\r\n    &lt;head&gt;\r\n        &lt;style&gt;\r\n            .tt-input, .tt-hint, .twitter-typeahead {\r\n                width: 100%;\r\n            }\r\n        &lt;\/style&gt;\r\n    &lt;\/head&gt;\r\n    &lt;body&gt;\r\n        &lt;div id=&quot;remote&quot;&gt;\r\n            &lt;input class=&quot;typeahead&quot; type=&quot;text&quot; placeholder=&quot;Songs...&quot;&gt;\r\n        &lt;\/div&gt;\r\n        &lt;script src=&quot;js\/jquery-3.3.1.min.js&quot;&gt;&lt;\/script&gt;\r\n        &lt;script src=&quot;js\/handlebars-v4.0.11.js&quot;&gt;&lt;\/script&gt;\r\n        &lt;script src=&quot;js\/typeahead.0.10.5.bundle.min.js&quot;&gt;&lt;\/script&gt;\r\n        &lt;script&gt;\r\n            $(&#039;#remote .typeahead&#039;).typeahead(\r\n                {\r\n                    hint: true,\r\n                    minLength: 3,\r\n                    highlight: false,\r\n                    limit: 5\r\n                }, {\r\n                    name: &quot;song&quot;,\r\n                    displayKey: &quot;id&quot;,\r\n                    source: function (query, callback) {\r\n                        $.getJSON(&quot;https:\/\/localhost:3000\/search?query=&quot; + query, function (data) {\r\n                            return callback(data);\r\n                        });\r\n                    },\r\n                    templates: {\r\n                        suggestion: Handlebars.compile(&#039;&lt;div&gt;{{title}} &ndash; {{artist}}&lt;\/div&gt;&#039;)\r\n                    }\r\n                }\r\n            );\r\n        &lt;\/script&gt;\r\n    &lt;\/body&gt;\r\n&lt;\/html&gt;<\/pre>\n<p>\uc2a4\ud0c0\uc77c\uacfc \uc2a4\ud06c\ub9bd\ud2b8\ub97c \ud3ec\ud568\ud558\uae30 \uc704\ud574 \uae30\ubcf8 HTML \ub9c8\ud06c\uc5c5\uc744 \uc218\ud589\ud55c \ubc29\ubc95\uc740 \ubb34\uc2dc\ud558\uace0 \ud0c0\uc774\ud504\ud5e4\ub4dc \uae30\ub2a5\uc73c\ub85c \ub118\uc5b4\uac00\uaca0\uc2b5\ub2c8\ub2e4. \uc124\uc815\uc5d0\uc11c\ub294 \ubc1c\uacac\ub41c \ubaa8\ub4e0 \ub808\ucf54\ub4dc\uc5d0 \ub300\ud574 \ud31d\uc5c5 \ud78c\ud2b8\ub97c \ud45c\uc2dc\ud558\uace0, \ucd5c\uc18c 3\uac1c \uc774\uc0c1\uc758 \ubb38\uc790\uac00 \uc788\uc5b4\uc57c \ud558\uba70, \uc77c\uce58\ud558\ub294 \ub2e8\uc5b4\ub294 \uac15\uc870 \ud45c\uc2dc\ud558\uc9c0 \uc54a\uace0, \ud45c\uc2dc\ub418\ub294 \ud56d\ubaa9\uc744 5\uac1c\ub85c \uc81c\ud55c\ud558\uaca0\uc2b5\ub2c8\ub2e4. \uc6d0\ud558\ub294 \uc0ac\uc591\uc5d0 \ub9de\uac8c \uc790\uc720\ub86d\uac8c \uc124\uc815\uc744 \uc870\uc815\ud558\uc138\uc694.<\/p>\n<p>\ub2e4\uc74c \uc139\uc158\uc5d0\uc11c\ub294 <code>displayKey<\/code>. \uc6b0\ub9ac\ub294 \uac1d\uccb4 \ubc30\uc5f4\uc744 \ubc18\ud658\ud558\uace0 \uc788\ub2e4\ub294 \uac83\uc744 \uc54c\uace0 \uc788\uc2b5\ub2c8\ub2e4. <code>id<\/code> \ub294 \ud574\ub2f9 \uac1d\uccb4\uc758 \uc18d\uc131 \uc911 \ud558\ub098\uc785\ub2c8\ub2e4. \uc120\ud0dd \ud6c4 \uc591\uc2dd\uc5d0 \ud574\ub2f9 \uac12\uc774 \ud45c\uc2dc\ub418\uae30\ub97c \uc6d0\ud569\ub2c8\ub2e4. \ub370\uc774\ud130 \uc18c\uc2a4\uc758 \uacbd\uc6b0 API \uc5d4\ub4dc\ud3ec\uc778\ud2b8\uc5d0 GET \uc694\uccad\uc744 \uc218\ud589\ud558\uace0 \uc751\ub2f5\uc744 \ud0c0\uc785\ud5e4\ub4dc \ub77c\uc774\ube0c\ub7ec\ub9ac\ub85c \ub2e4\uc2dc \uc804\ub2ec\ud569\ub2c8\ub2e4. \ubaa8\ub4e0 \uac83\uc774 <code>\ud15c\ud50c\ub9bf<\/code> \uc601\uc5ed\uc785\ub2c8\ub2e4.<\/p>\n<h2>\uacb0\ub860<\/h2>\n<p>Couchbase\uc5d0\uc11c jQuery, Node.js \ubc0f \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9(FTS)\uc744 \uc0ac\uc6a9\ud558\uc5ec \uc790\ub3d9 \uc81c\uc548 \ub610\ub294 \uc790\ub3d9 \uc644\uc131\uc774\ub77c\uace0\ub3c4 \ud558\ub294 \ud0c0\uc785\uc5d0\uc774\ud5e4\ub4dc\ub97c \uc0ac\uc6a9\ud558\ub294 \ubc29\ubc95\uc744 \uc0b4\ud3b4\ubcf4\uc558\uc2b5\ub2c8\ub2e4. \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9\uacfc \uad00\ub828\ud558\uc5ec \ub9ce\uc740 \uc0ac\uc6a9 \uc0ac\ub840\uac00 \uc788\uc73c\uba70 \ud0c0\uc785\ud5e4\ub4dc \uae30\ub2a5\uc5d0 \uc0ac\uc6a9\ud560 \uc218 \uc788\ub294 \ub2e4\uc591\ud55c \ub77c\uc774\ube0c\ub7ec\ub9ac\uac00 \uc788\uc2b5\ub2c8\ub2e4. \uc774 \ud29c\ud1a0\ub9ac\uc5bc\uc740 \ud5a5\ud6c4\uc5d0 \ub300\ud55c \uc544\uc774\ub514\uc5b4\ub97c \uc81c\uacf5\ud558\uae30 \uc704\ud55c \uac83\uc785\ub2c8\ub2e4.<\/p>\n<p>Node.js\uc640 \ud568\uaed8 Couchbase\ub97c \uc0ac\uc6a9\ud558\ub294 \ubc29\ubc95\uc5d0 \ub300\ud55c \uc790\uc138\ud55c \ub0b4\uc6a9\uc740 <a href=\"https:\/\/www.couchbase.com\/blog\/ko\/developers\/\" target=\"_blank\" rel=\"noopener noreferrer\">\uce74\uc6b0\uce58\ubca0\uc774\uc2a4 \uac1c\ubc1c\uc790 \ud3ec\ud138<\/a>.<\/p>","protected":false},"excerpt":{"rendered":"<p>Over the past year or so I&#8217;ve written a variety of tutorials around the full-text search (FTS) service of Couchbase, most of which are specific examples of how to do something with one of the SDKs and never really anything [&hellip;]<\/p>","protected":false},"author":63,"featured_media":5555,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"inline_featured_image":false,"footnotes":""},"categories":[1814,1816,2165,9327,1822],"tags":[1543,2259],"ppma_author":[9032],"class_list":["post-5551","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-application-design","category-couchbase-server","category-full-text-search","category-javascript","category-node-js","tag-javascript","tag-typeahead"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v25.8 (Yoast SEO v25.8) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js<\/title>\n<meta name=\"description\" content=\"Learn to create a UI typeahead that populates based on data from Couchbase Full-Text Search (FTS) service using Node.js, jQuery, Typeahead.js.\" \/>\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.couchbase.com\/blog\/ko\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/\" \/>\n<meta property=\"og:locale\" content=\"ko_KR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js\" \/>\n<meta property=\"og:description\" content=\"Learn to create a UI typeahead that populates based on data from Couchbase Full-Text Search (FTS) service using Node.js, jQuery, Typeahead.js.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.couchbase.com\/blog\/ko\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/\" \/>\n<meta property=\"og:site_name\" content=\"The Couchbase Blog\" \/>\n<meta property=\"article:author\" content=\"https:\/\/www.facebook.com\/thepolyglotdeveloper\" \/>\n<meta property=\"article:published_time\" content=\"2018-08-03T14:00:44+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-06-14T03:14:57+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1920\" \/>\n\t<meta property=\"og:image:height\" content=\"1003\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"Nic Raboy, Developer Advocate, Couchbase\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@nraboy\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Nic Raboy, Developer Advocate, Couchbase\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"5\ubd84\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/\"},\"author\":{\"name\":\"Nic Raboy, Developer Advocate, Couchbase\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/#\/schema\/person\/bb545ebe83bb2d12f91095811d0a72e1\"},\"headline\":\"Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js\",\"datePublished\":\"2018-08-03T14:00:44+00:00\",\"dateModified\":\"2025-06-14T03:14:57+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/\"},\"wordCount\":1046,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/#organization\"},\"image\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg\",\"keywords\":[\"javascript\",\"typeahead\"],\"articleSection\":[\"Application Design\",\"Couchbase Server\",\"Full-Text Search\",\"JavaScript\",\"Node.js\"],\"inLanguage\":\"ko-KR\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/\",\"url\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/\",\"name\":\"Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js\",\"isPartOf\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg\",\"datePublished\":\"2018-08-03T14:00:44+00:00\",\"dateModified\":\"2025-06-14T03:14:57+00:00\",\"description\":\"Learn to create a UI typeahead that populates based on data from Couchbase Full-Text Search (FTS) service using Node.js, jQuery, Typeahead.js.\",\"breadcrumb\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#breadcrumb\"},\"inLanguage\":\"ko-KR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"ko-KR\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage\",\"url\":\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg\",\"contentUrl\":\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg\",\"width\":1920,\"height\":1003},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/www.couchbase.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/#website\",\"url\":\"https:\/\/www.couchbase.com\/blog\/\",\"name\":\"The Couchbase Blog\",\"description\":\"Couchbase, the NoSQL Database\",\"publisher\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.couchbase.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"ko-KR\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/#organization\",\"name\":\"The Couchbase Blog\",\"url\":\"https:\/\/www.couchbase.com\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"ko-KR\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/2023\/04\/admin-logo.png\",\"contentUrl\":\"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/2023\/04\/admin-logo.png\",\"width\":218,\"height\":34,\"caption\":\"The Couchbase Blog\"},\"image\":{\"@id\":\"https:\/\/www.couchbase.com\/blog\/#\/schema\/logo\/image\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/#\/schema\/person\/bb545ebe83bb2d12f91095811d0a72e1\",\"name\":\"Nic Raboy, Developer Advocate, Couchbase\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"ko-KR\",\"@id\":\"https:\/\/www.couchbase.com\/blog\/#\/schema\/person\/image\/8863514d8bed0cf6080f23db40e00354\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/bedeb68368d4681aca4c74fe5f697f0c423b80d498ec50fd915ba018b72c101f?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/bedeb68368d4681aca4c74fe5f697f0c423b80d498ec50fd915ba018b72c101f?s=96&d=mm&r=g\",\"caption\":\"Nic Raboy, Developer Advocate, Couchbase\"},\"description\":\"Nic Raboy is an advocate of modern web and mobile development technologies. He has experience in Java, JavaScript, Golang and a variety of frameworks such as Angular, NativeScript, and Apache Cordova. Nic writes about his development experiences related to making web and mobile development easier to understand.\",\"sameAs\":[\"https:\/\/www.thepolyglotdeveloper.com\",\"https:\/\/www.facebook.com\/thepolyglotdeveloper\",\"https:\/\/x.com\/nraboy\"],\"url\":\"https:\/\/www.couchbase.com\/blog\/ko\/author\/nic-raboy-2\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\ud0c0\uc785\ud5e4\ub4dc: Couchbase \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9 \ubc0f Node.js\ub85c \uac1c\ubc1c\ud558\uae30","description":"Node.js, jQuery, Typeahead.js\ub97c \uc0ac\uc6a9\ud558\uc5ec Couchbase \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9(FTS) \uc11c\ube44\uc2a4\uc758 \ub370\uc774\ud130\ub97c \uae30\ubc18\uc73c\ub85c \ucc44\uc6cc\uc9c0\ub294 UI \ud0c0\uc785\ud5e4\ub4dc\ub97c \ub9cc\ub4dc\ub294 \ubc29\ubc95\uc744 \uc54c\uc544\ubcf4\uc138\uc694.","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.couchbase.com\/blog\/ko\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/","og_locale":"ko_KR","og_type":"article","og_title":"Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js","og_description":"Learn to create a UI typeahead that populates based on data from Couchbase Full-Text Search (FTS) service using Node.js, jQuery, Typeahead.js.","og_url":"https:\/\/www.couchbase.com\/blog\/ko\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/","og_site_name":"The Couchbase Blog","article_author":"https:\/\/www.facebook.com\/thepolyglotdeveloper","article_published_time":"2018-08-03T14:00:44+00:00","article_modified_time":"2025-06-14T03:14:57+00:00","og_image":[{"width":1920,"height":1003,"url":"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg","type":"image\/jpeg"}],"author":"Nic Raboy, Developer Advocate, Couchbase","twitter_card":"summary_large_image","twitter_creator":"@nraboy","twitter_misc":{"Written by":"Nic Raboy, Developer Advocate, Couchbase","Est. reading time":"5\ubd84"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#article","isPartOf":{"@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/"},"author":{"name":"Nic Raboy, Developer Advocate, Couchbase","@id":"https:\/\/www.couchbase.com\/blog\/#\/schema\/person\/bb545ebe83bb2d12f91095811d0a72e1"},"headline":"Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js","datePublished":"2018-08-03T14:00:44+00:00","dateModified":"2025-06-14T03:14:57+00:00","mainEntityOfPage":{"@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/"},"wordCount":1046,"commentCount":0,"publisher":{"@id":"https:\/\/www.couchbase.com\/blog\/#organization"},"image":{"@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage"},"thumbnailUrl":"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg","keywords":["javascript","typeahead"],"articleSection":["Application Design","Couchbase Server","Full-Text Search","JavaScript","Node.js"],"inLanguage":"ko-KR","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/","url":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/","name":"\ud0c0\uc785\ud5e4\ub4dc: Couchbase \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9 \ubc0f Node.js\ub85c \uac1c\ubc1c\ud558\uae30","isPartOf":{"@id":"https:\/\/www.couchbase.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage"},"image":{"@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage"},"thumbnailUrl":"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg","datePublished":"2018-08-03T14:00:44+00:00","dateModified":"2025-06-14T03:14:57+00:00","description":"Node.js, jQuery, Typeahead.js\ub97c \uc0ac\uc6a9\ud558\uc5ec Couchbase \uc804\uccb4 \ud14d\uc2a4\ud2b8 \uac80\uc0c9(FTS) \uc11c\ube44\uc2a4\uc758 \ub370\uc774\ud130\ub97c \uae30\ubc18\uc73c\ub85c \ucc44\uc6cc\uc9c0\ub294 UI \ud0c0\uc785\ud5e4\ub4dc\ub97c \ub9cc\ub4dc\ub294 \ubc29\ubc95\uc744 \uc54c\uc544\ubcf4\uc138\uc694.","breadcrumb":{"@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#breadcrumb"},"inLanguage":"ko-KR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/"]}]},{"@type":"ImageObject","inLanguage":"ko-KR","@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#primaryimage","url":"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg","contentUrl":"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/sites\/1\/2018\/07\/labyrinth-2037286_1920.jpg","width":1920,"height":1003},{"@type":"BreadcrumbList","@id":"https:\/\/www.couchbase.com\/blog\/developing-a-typeahead-with-couchbase-node-js-and-full-text-search\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.couchbase.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Typeahead: Develop with Couchbase Full-Text Search &amp; Node.js"}]},{"@type":"WebSite","@id":"https:\/\/www.couchbase.com\/blog\/#website","url":"https:\/\/www.couchbase.com\/blog\/","name":"\uce74\uc6b0\uce58\ubca0\uc774\uc2a4 \ube14\ub85c\uadf8","description":"NoSQL \ub370\uc774\ud130\ubca0\uc774\uc2a4, Couchbase","publisher":{"@id":"https:\/\/www.couchbase.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.couchbase.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"ko-KR"},{"@type":"Organization","@id":"https:\/\/www.couchbase.com\/blog\/#organization","name":"\uce74\uc6b0\uce58\ubca0\uc774\uc2a4 \ube14\ub85c\uadf8","url":"https:\/\/www.couchbase.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"ko-KR","@id":"https:\/\/www.couchbase.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/2023\/04\/admin-logo.png","contentUrl":"https:\/\/www.couchbase.com\/blog\/wp-content\/uploads\/2023\/04\/admin-logo.png","width":218,"height":34,"caption":"The Couchbase Blog"},"image":{"@id":"https:\/\/www.couchbase.com\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/www.couchbase.com\/blog\/#\/schema\/person\/bb545ebe83bb2d12f91095811d0a72e1","name":"Nic Raboy, \uac1c\ubc1c\uc790 \uc639\ud638\uc790, Couchbase","image":{"@type":"ImageObject","inLanguage":"ko-KR","@id":"https:\/\/www.couchbase.com\/blog\/#\/schema\/person\/image\/8863514d8bed0cf6080f23db40e00354","url":"https:\/\/secure.gravatar.com\/avatar\/bedeb68368d4681aca4c74fe5f697f0c423b80d498ec50fd915ba018b72c101f?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/bedeb68368d4681aca4c74fe5f697f0c423b80d498ec50fd915ba018b72c101f?s=96&d=mm&r=g","caption":"Nic Raboy, Developer Advocate, Couchbase"},"description":"\ub2c9 \ub77c\ubcf4\uc774\ub294 \ucd5c\uc2e0 \uc6f9 \ubc0f \ubaa8\ubc14\uc77c \uac1c\ubc1c \uae30\uc220\uc744 \uc639\ud638\ud558\ub294 \uc0ac\ub78c\uc785\ub2c8\ub2e4. \uadf8\ub294 Java, JavaScript, Golang \ubc0f Angular, NativeScript, Apache Cordova\uc640 \uac19\uc740 \ub2e4\uc591\ud55c \ud504\ub808\uc784\uc6cc\ud06c\uc5d0 \ub300\ud55c \uacbd\ud5d8\uc774 \uc788\uc2b5\ub2c8\ub2e4. Nic\uc740 \uc6f9 \ubc0f \ubaa8\ubc14\uc77c \uac1c\ubc1c\uc744 \ubcf4\ub2e4 \uc27d\uac8c \uc774\ud574\ud560 \uc218 \uc788\ub3c4\ub85d \uc790\uc2e0\uc758 \uac1c\ubc1c \uacbd\ud5d8\uc5d0 \ub300\ud574 \uae00\uc744 \uc4f0\uace0 \uc788\uc2b5\ub2c8\ub2e4.","sameAs":["https:\/\/www.thepolyglotdeveloper.com","https:\/\/www.facebook.com\/thepolyglotdeveloper","https:\/\/x.com\/nraboy"],"url":"https:\/\/www.couchbase.com\/blog\/ko\/author\/nic-raboy-2\/"}]}},"authors":[{"term_id":9032,"user_id":63,"is_guest":0,"slug":"nic-raboy-2","display_name":"Nic Raboy, Developer Advocate, Couchbase","avatar_url":"https:\/\/secure.gravatar.com\/avatar\/bedeb68368d4681aca4c74fe5f697f0c423b80d498ec50fd915ba018b72c101f?s=96&d=mm&r=g","author_category":"","last_name":"Raboy","first_name":"Nic","job_title":"","user_url":"https:\/\/www.thepolyglotdeveloper.com","description":"\ub2c9 \ub77c\ubcf4\uc774\ub294 \ucd5c\uc2e0 \uc6f9 \ubc0f \ubaa8\ubc14\uc77c \uac1c\ubc1c \uae30\uc220\uc744 \uc639\ud638\ud558\ub294 \uc0ac\ub78c\uc785\ub2c8\ub2e4. \uadf8\ub294 Java, JavaScript, Golang \ubc0f Angular, NativeScript, Apache Cordova\uc640 \uac19\uc740 \ub2e4\uc591\ud55c \ud504\ub808\uc784\uc6cc\ud06c\uc5d0 \ub300\ud55c \uacbd\ud5d8\uc774 \uc788\uc2b5\ub2c8\ub2e4. Nic\uc740 \uc6f9 \ubc0f \ubaa8\ubc14\uc77c \uac1c\ubc1c\uc744 \ubcf4\ub2e4 \uc27d\uac8c \uc774\ud574\ud560 \uc218 \uc788\ub3c4\ub85d \uc790\uc2e0\uc758 \uac1c\ubc1c \uacbd\ud5d8\uc5d0 \ub300\ud574 \uae00\uc744 \uc4f0\uace0 \uc788\uc2b5\ub2c8\ub2e4."}],"_links":{"self":[{"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/posts\/5551","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/users\/63"}],"replies":[{"embeddable":true,"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/comments?post=5551"}],"version-history":[{"count":0,"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/posts\/5551\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/media\/5555"}],"wp:attachment":[{"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/media?parent=5551"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/categories?post=5551"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/tags?post=5551"},{"taxonomy":"author","embeddable":true,"href":"https:\/\/www.couchbase.com\/blog\/ko\/wp-json\/wp\/v2\/ppma_author?post=5551"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}