{"id":1505,"date":"2019-05-21T18:34:00","date_gmt":"2019-05-21T09:34:00","guid":{"rendered":"http:\/\/idealive.jp\/blog\/?p=1505"},"modified":"2019-05-21T18:34:00","modified_gmt":"2019-05-21T09:34:00","slug":"cakephp2-x%e3%81%a7typeahead-js%e3%82%92%e4%bd%bf%e3%81%86","status":"publish","type":"post","link":"https:\/\/idealive.jp\/blog\/2019\/05\/21\/cakephp2-x%e3%81%a7typeahead-js%e3%82%92%e4%bd%bf%e3%81%86\/","title":{"rendered":"CakePHP2.x\u3067typeahead.js\u3092\u4f7f\u3046"},"content":{"rendered":"<p>\u3053\u3093\u306b\u3061\u306f sohnishi \u3067\u3059\u3002<\/p>\n<p>typeahead.js\u3092\u4f7f\u3063\u3066\u5165\u529b\u88dc\u5b8c\u6a5f\u80fd\u3092\u4f7f\u3063\u3066\u307f\u3088\u3046\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u307e\u305a\u306f<a href=\"https:\/\/github.com\/twitter\/typeahead.js\/\">https:\/\/github.com\/twitter\/typeahead.js\/<\/a><\/p>\n<p>\u304b\u3089js\u3092\u843d\u3068\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u30d5\u30ed\u30f3\u30c8\u306e\u30b3\u30fc\u30c9\u5168\u6587\u3067\u3059\u3002<\/p>\n<pre class=\"lang:default decode:true\" title=\"index.ctp\">&lt;?php echo $this-&gt;Html-&gt;script('typeahead.bundle.min', array('inline' =&gt; false)); ?&gt;\r\n&lt;?php $this-&gt;Html-&gt;scriptStart(array('inline' =&gt; false));?&gt;\r\n\r\n$(function () {\r\n\t\r\n\tvar hoges = new Bloodhound({\r\n\t\tremote: '&lt;?php echo $this-&gt;Html-&gt;url(array('plugin' =&gt; 'hoges', 'controller' =&gt; 'hoges', 'action' =&gt; 'typeahead', '?' =&gt; 'q=%QUERY')); ?&gt;,\r\n\t\tdatumTokenizer: function (d) {\r\n\t\t\treturn Bloodhound.tokenizers.whitespace(d.name);\r\n\t\t},\r\n\t\tqueryTokenizer: Bloodhound.tokenizers.whitespace,\r\n\t});\r\n\r\n\thoges.initialize();\r\n\r\n\t$('#HogeHogevalue').typeahead({\r\n\t\thint: false,\r\n\t\thighlight: true,\r\n\t\tminLength: 2\r\n\t},\r\n\t{\r\n\t\tname: 'hoges',\r\n\t\tdisplayKey: 'name',\r\n\t\tsource: hoges.ttAdapter()\r\n\t});\r\n\r\n\t\r\n});\r\n&lt;?php $this-&gt;Html-&gt;scriptEnd();?&gt;\r\n\r\n\r\n&lt;?php echo $this-&gt;Form-&gt;create(); ?&gt;\r\n\r\n&lt;?php echo $this-&gt;Form-&gt;input('hogevalue'); ?&gt;\r\n\r\n&lt;?php echo $this-&gt;Form-&gt;submit('\u9001\u4fe1'); ?&gt;\r\n\r\n&lt;?php echo $this-&gt;Form-&gt;end(); ?&gt;<\/pre>\n<p>typeahead.bundle.min.js\u3092\u8aad\u307f\u8fbc\u307f\u3001<\/p>\n<p>Bloodhound\u3092\u521d\u671f\u5316\u3057\u307e\u3059\u3002<\/p>\n<p>\u5404\u30aa\u30d7\u30b7\u30e7\u30f3\u306e\u8aac\u660e\u306f\u3001<\/p>\n<p><a href=\"https:\/\/github.com\/twitter\/typeahead.js\/blob\/master\/doc\/bloodhound.md#options\">https:\/\/github.com\/twitter\/typeahead.js\/blob\/master\/doc\/bloodhound.md#options<\/a><\/p>\n<p>\u306b\u8a73\u3057\u304f\u8f09\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u305d\u306e\u5f8c\u3001input\u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u5bfe\u3057\u3066\u3001Typehead \u3092\u6709\u52b9\u306b\u3057\u307e\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>\u30b5\u30fc\u30d0\u30fc\u30b5\u30a4\u30c9\u3067\u3059\u3002<\/p>\n<pre class=\"lang:default decode:true\" title=\"HogesController.php\">public function typeahead() {\r\n\t$this-&gt;autoRender = false;\r\n\tif ($this-&gt;request-&gt;is('ajax')) {\r\n\t\t$turm = $this-&gt;request-&gt;query['q'];\r\n\t\t$results = $this-&gt;Hoge-&gt;find('all', array(\r\n\t\t\t'conditions' =&gt; array(\r\n\t\t\t\t'Hoge.name LIKE' =&gt; $turm . '%'\r\n\t\t\t)\r\n\t\t));\r\n\t\t$hoges = array();\r\n\t\tforeach ($results as $key =&gt; $result) {\r\n\t\t\t$val['id'] = $result['Hoge']['id'];\r\n\t\t\t$val['name'] = $result['Hoge']['name'];\r\n\t\t\tarray_push($hoges, $val);\r\n\t\t}\r\n\t\techo json_encode($hoges);\r\n\t}\r\n}<\/pre>\n<p>&nbsp;<\/p>\n<p>\u53d7\u3051\u53d6\u3063\u305f\u5024\u3092\u5143\u306b\u691c\u7d22\u3057\u3001\u5024\u3092\u8fd4\u3059\u3002\u666e\u901a\u306e\u51e6\u7406\u3067\u3059\u3002<\/p>\n<p>\u672c\u65e5\u306f\u4ee5\u4e0a\u3067\u3059\u3002\u305d\u308c\u3067\u306f\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3053\u3093\u306b\u3061\u306f sohnishi \u3067\u3059\u3002 typeahead.js\u3092\u4f7f\u3063\u3066\u5165\u529b\u88dc\u5b8c\u6a5f\u80fd\u3092\u4f7f\u3063\u3066\u307f\u3088\u3046\u3068\u601d\u3044\u307e\u3059\u3002 \u307e\u305a\u306fhttps:\/\/github.com\/twitter\/typeahead.js\/ \u304b\u3089js\u3092\u843d\u3068\u3057\u307e\u3057\u3087&#8230;<a class=\"read-more-link button\" href=\"https:\/\/idealive.jp\/blog\/2019\/05\/21\/cakephp2-x%e3%81%a7typeahead-js%e3%82%92%e4%bd%bf%e3%81%86\/\">\u7d9a\u304d\u3092\u8aad\u3080<\/a><\/p>\n","protected":false},"author":3,"featured_media":1507,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[23,19,1],"tags":[],"class_list":["post-1505","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-cakephp","category-php","category-1"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts\/1505"}],"collection":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/comments?post=1505"}],"version-history":[{"count":1,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts\/1505\/revisions"}],"predecessor-version":[{"id":1506,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts\/1505\/revisions\/1506"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/media\/1507"}],"wp:attachment":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/media?parent=1505"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/categories?post=1505"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/tags?post=1505"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}