質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

3410閲覧

cakephpでオートコンプリート機能

atsupoooon

総合スコア47

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2015/12/23 11:33

編集2015/12/24 12:26

Cakephpでオートコンプリート機能を実装したいと思っていますが、
全く実装できない状況です。

具体的な内容を記載していませんでした。

下記サイトを参考して、
http://wataame.sumomo.ne.jp/archives/7190

1.jQueryとjQuery UIを読み込みました。

2.フォームの作成

<?php echo $this->Form->input('name', array( 'type' => 'text', 'id' => 'autocomplete', )); ?>

3.Javascriptの読み込み

<script> $(function() { var availableTags = [ "ActionScript", "AppleScript", "Asp", "BASIC", "C", "C++", "Clojure", "COBOL", "ColdFusion", "Erlang", "Fortran", "Groovy", "Haskell", "Java", "JavaScript", "Lisp", "Perl", "PHP", "Python", "Ruby", "Scala", "Scheme" ]; $("#autocomplete").autocomplete({ source: availableTags, autoFocus: true, delay: 500, minLength: 1 }); }); </script>

1~3までの手順を実施して問題なく、指定のフォームに
Javascriptのリストがフォームの下に表示され選択できるようになりました。

4.Javascriptの変更
3.の内容を下記に変更

<script type="text/javascript"> $(function(){ $('#autocomplete').autocomplete({ source: '<?php echo $this->Html->url(array('controller' => 'testA', 'action' => 'autocomplete')); ?>', autoFocus: true, delay: 500, minLength: 2 }); }) </script>

**5.コントローラーの作成 **
こちらはこのURLを参考にしました。
https://teratail.com/questions/18856

public

1 $this->loadModel('testB'); 2 $field = 'name'; 3 $term = $this->params['url']['term']; 4 5 $condition = array(); 6 if(!empty($term)){ 7 $condition = array('testB.'.$field.' like' => "%".$term."%"); 8 } 9 10 $query = array( 11 'fields' => array($field), 12 'conditions' => $condition, 13 'limit' => 10, 14 'order' => array('testB.'.$field => 'ASC'), 15 'group' => $field, 16 ); 17 18 $data = array(); 19 $items = $this->testB->find('all', $query); 20 21 foreach ($items as $item) { 22 $cnt = array_push($data, $item['testB'][$field]); 23 } 24 25 // JSONデータのみを返す 26 $this->viewClass = 'Json'; 27 $this->set(compact('data')); 28 $this->set('_serialize', 'data'); 29}

jsonの値を確認。
下記のURLから
http://localhost:8888/cakephp/test/autocomplete?term=

このデータが返ってきました。
[
"aaaaaa",
"test",
]

データベースの中身を取得できている。と思います。。おそらく。。。

6.フォームの確認
指定したフォームにaと入れてもリストが表示されません。

どこかで値がちゃんと渡されていないのでしょうか。

ご指摘していただけますでしょうか。
よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TaMaMhyu

2015/12/24 04:27

具体的にどのようにしたのかと、結果どうなったのか、を示したほうが良いかと思います。
atsupoooon

2015/12/24 12:25 編集

ご指摘ありがとうございました。 内容を変更いたしました。
guest

回答1

0

ベストアンサー

4の「Javascriptの変更」のところですが、ブラウザでソースを見てsourceに意図したURLが入っていますか?
また、Modelが「testB」となっていてControllerには「testA」とありますが、このあたりは大丈夫でしょうか。

投稿2015/12/24 13:30

jinco

総合スコア432

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

atsupoooon

2015/12/24 14:10

ご指摘ありがとうございます。 4の「Javascriptの変更」のところですが、ブラウザでソースを見てsourceに意図したURLが入っていますか? >>>>>>>>下記のようになっております。 <script type="text/javascript"> $(function(){ $('#autocomplete').autocomplete({ source: '/builds/autocomplete', }); }) </script> >>>>>>> また、Modelが「testB」となっていてControllerには「testA」とありますが、このあたりは大丈夫でしょうか。 >>>>>すべてtestBやすべてtestAとしても また、testAとtestBを入れ替えてもだめでした。 jsonはこちらのURLから確認できますが、 フォームのリストが全く表示されませんでした。 やりたい動作は、 testAのページからtestBのデータベースの中身(nameのフィールドのみ)を オートコンプリート機能のリストとして表示させたいです。 一様この方法も試しました。 コントローラーを以下に変更して試しました。 >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> public function autocomplete(){ $result = array( ['id' => '1', 'value' => 'item1'], ['id' => '2', 'value' => 'item2'], ['id' => '3', 'value' => 'item3'], ); $this->viewClass = 'Json'; $this->set(compact('result')); $this->set('_serialize', 'result'); } >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 上記の内容に変更してリストが表示できませんでした。
jinco

2015/12/24 14:19

「jsonはこちらのURLから確認できます」とのことですが、このページでデータがjson形式で表示されているのであれば、そのURLを直接Javascriptのsource部分に書いてみると動きませんか? $('#autocomplete').autocomplete({ source: 'ここにそのURLを入力。PHPは使わずにベタ打ち',
atsupoooon

2015/12/24 14:54

しっかりと動作しました!!!! ベタ打ちでいけました。 夜分遅くまでご指摘したいただきありがとうございます。 1つお伺いしてもよろしいですか? なぜ、ベタ打ちでは動くのでしょうか? パスはあっていると思いますが。。。
jinco

2015/12/27 13:12

遅くなってすみません。おそらくphpで出力したパスのどこかが間違っているのだと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問