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

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

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

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

AngularJS

AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

1回答

612閲覧

angular.jsでscopeが効きません

shukonda

総合スコア13

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

AngularJS

AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2017/09/25 02:33

SpringBoot + Angularjsで野球チーム一覧を表示するプログラムを書いています。
Chromeで見たところjsonでデータを受け取るのは出来ているのですが、Viewに反映されません。
原因を教えて頂けますと幸いです。

javascript

1angular.module('myApp', []) 2 .controller('myCtrl', ['$scope',function($scope){ 3 4 $.ajax({ 5 type: 'GET', 6 url: '/5km/allteams', 7 dataType: 'json' 8 }).then(function(json){ 9 10 $scope.teams = json; //ここはデータが取れています 11 12 }); 13 } 14]);

jspファイル

html

1<%@ page contentType="text/html; charset=UTF-8"%> 2<!DOCTYPE html> 3<html lang="ja" ng-app="myApp"> 4<head> 5<meta charset="UTF-8"> 6<title>野球チーム一覧</title> 7<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.5/angular.min.js"></script> 8<script src="${pageContext.request.contextPath}/team.js"></script> 9</head> 10<body ng-controller="myCtrl"> 11<h1>プロ野球<br>セントラルリーグ一覧</h1> 12<ul> 13<li ng-repeat="team in teams"> 14<a href="${pageContext.request.contextPath}/team-detail?id={{team.id}}"> 15{{team.teamName}}</a> 16</li> 17</ul> 18<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script> 19</body> 20</html>

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

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

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

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

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

guest

回答1

0

ベストアンサー

$scope.teams = json;

$timeout
で括ってみてください。

以下例です。

js

1angular.module('myApp', []) 2 .controller('myCtrl', ['$scope','$timeout',function($scope, $timeout){ 3 4 $.ajax({ 5 type: 'GET', 6 url: '/5km/allteams', 7 dataType: 'json' 8 }).then(function(json){ 9 $timeout(function() { 10 $scope.teams = json; 11 }); 12 }); 13 } 14]); 15

AngularJSはdigestループというアルゴリズムで値の変更検知と再描画を行っています。
このdigestループを開始するトリガーとなる処理が$scope.$apply()なのですが、
$timeoutは内部的に$scope.$apply()を呼びだしているため、digestループが開始され、値の変更を検知し、描画されます。

digestループはng-clickで呼びだされた関数などに関しては自動で呼び出されますが、
$.ajax(jQueryのAjax機能)はAngularJSの管理外のため、レスポンス返却後にdigestループが開始されません。
そこで、$timeoutを呼び出し、digestループを開始させています。

ただ、$httpサービスというAngularJSの標準Ajax機能を使用すれば、レスポンス返却後にdigestループが開始されるので、こちらの使用をおすすめします。
参考: http://www.buildinsider.net/web/angularjstips/0035

投稿2017/09/25 03:59

編集2017/09/25 04:03
kishisuke

総合スコア28

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

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

shukonda

2017/09/25 04:13

なるほどjQueryとの相性は悪いのですね。$httpサービスを使った実装でうまくいきました。大変勉強になりました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問