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

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

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

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

AngularJS

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

Q&A

解決済

3回答

5866閲覧

AngularJSでControllerの関数をHTMLから呼びたい

mag-chang

総合スコア12

MongoDB

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

AngularJS

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

0グッド

1クリップ

投稿2016/02/28 14:36

最近Webアプリケーションおよびjavascriptを勉強し始めました。

今回、YeomanのMEANスタックであるAngularJS Full-Stack generatorを使って
Teitter風のWebアプリケーションを作成しようとしています。

参考にしているサイトはこちらです

client/app/main/main.controller.jsで自分の投稿を判定する関数を追加し、
main.htmlの中で呼び出したいのですが、うまく呼び出せません。

  • main.controller.js

javascript

1angular.module('testApp') 2.controller('MainController', function ($scope, $http, socket, Auth) { 3 $scope.isLoggedIn = Auth.isLoggedIn; 4 $scope.getCurrentUser = Auth.getCurrentUser; 5 $scope.isMyTweet = function(thing){ 6 return Auth.isLoggedIn() && thing.user && thing.user._id===Auth.getCurrentUser()._id; 7 }; 8 }); 9})();
  • main.html

html

1<div class="row"> 2 <div ng-repeat="thing in main.awesomeThings"> 3 {{thing.user.name}} - {{thing.name}} ({{thing.createdAt}}) 4 <button type="button" class="close" ng-if="isMyTweet(thing)" ng-click="main.deleteThing(thing)">&times;</button> 5 </div> 6</div>

上記の記述で、ng-if="isMyTweet(thing)"の部分が正しく動作していない状況です。

どなたか上記コードの問題点をご教授頂きたいです。
宜しくお願い致します。

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

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

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

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

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

guest

回答3

0

パッと見でおかしな点というと、JavaScrptのコードの最後の一行(下記)はJavaScriptの実行エラーの原因になるような気がします。

})();

それ以外、Angularの構文としては明らかな間違いは見当たりません。
ただし、HTML側の ng-app="testApp" 宣言と、ng-controller="MainController" の宣言が正しく行われて入れているかどうか、確認されたほうが良いかとは思います。

いずれにしても、Angularのコードがうまく動かない(画面表示が不完全な状態になる、ボタンのアクションが反応しない等)場合、JavaScript実行エラーが発生していることが多いです。
ブラウザの開発者ツール画面を表示(IEやChromeではF12キーで表示される)した状態で、このページをリロードしてみると実行エラーの有無を確認できます。
また、Angular関連のJavaScript実行エラーのエラーメッセージに含まれている "http://errors.angularjs.org/..." の部分をコピーしてブラウザでここを開くと、実行エラーの発生原因に関する説明を得ることができますので、そちらの情報もご覧になってみてください。

ご参考になれば。

投稿2016/02/29 00:26

tkanda

総合スコア2425

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

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

mag-chang

2016/04/22 14:24

ブラウザの開発者ツール画面でのデバッグ方法を知ることができました。 ありがとうございました。
guest

0

ベストアンサー

<div ng-repeat="thing in main.awesomeThings">で$scopeが異なるので、
その下の要素ではisMyTweet(thing)が定義定義されていない様に思います。

{{$id}}とすると$scopeのIDが表示できますが、ngRepeatの中と外では値が違うと思います。

<button type="button" class="close" ng-if="$parent.isMyTweet(thing)" ng-click="main.deleteThing(thing)">&times;</button>
とすると、動作するかもしれませんが、$scopeを使わない方向で実装したほうがよいと思います。

具体的には、コントローラに定義してControllerAsで指定した別名でHTMLから利用するのをお勧めします。

投稿2016/03/28 09:32

dayomaru

総合スコア15

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

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

mag-chang

2016/04/22 14:23

ご回答いただいた通り、$scopeを使用せず controller as にて指定したコントローラ名で呼び出したところ 動作しました。 ありがとうございました。
guest

0

})();

(js 部分の最後の一行は、転載ミスとみなしますと。。。)
該当部分の記述方法は特に間違っていないと思われます。
にもかかわらず動いていないということは、他の箇所に問題の原因があると思われます。

  1. main.controller.js を読み込んでいるかどうか
  2. main.controller.js の文法エラーが発生していないか
  3. ng-controller の記述が行われていない
  4. HTML の記述ミス(&ブラウザによる自動補完)により DOM 構造が壊れてしまい、ng-controller の影響範囲から外れてしまっている

…… 等。

あと、とりあえず、isMyTweet 関数の中にて console.log (もしくは alert) を記述し、関数が呼び出されているかどうかも確認してみてください。
意外と、関数は呼び出されているけど、評価式のミスなどもあり得ますので。。。

投稿2016/02/29 00:07

編集2016/02/29 00:12
usk

総合スコア397

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

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

mag-chang

2016/04/22 14:24

console.logでのデバッグ方法を知ることができました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問