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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

AngularJS

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

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

Q&A

解決済

1回答

1401閲覧

OnsenUI + Angularでコントロールにセットした値が引数として認識されない

kokegreen

総合スコア7

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

AngularJS

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

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

0グッド

0クリップ

投稿2018/05/16 14:54

発生している現象

MonacaによるOnsenUI+Angularで一覧画面にあるリストを選択するとその内容が詳細画面に表示されるような画面を実装しています。

詳細画面の初回起動時はすべてのコントロールが空の状態なので、各コントロールに値をセットし、追加ボタンを押下すると、一覧画面にセットした値が登録されることを確認しました。

先程登録した情報を一覧画面から選択すると、その情報を引き継いで詳細画面に表示することができました。

その後、詳細の情報を何も選択せずに追加ボタンを押下すると、呼び出したデータと同一のデータが一覧に登録されてほしいのですが、全て空のデータが登録されてしまいます。

該当のソースコード

<script> ons.bootstrap() .controller('MyController', ['$scope', function($scope) { $scope.members = []; $scope.itemize = [ { item: 'テスト', cost: '20000', paymember_id: 0, paymember_name : 'ユーザー1' }, $scope.addItem = function(item,cost,paymember_id,rowindex){ $scope.itemize.push({item:item, cost:cost, paymember_id:paymember_id, paymember_name:$scope.members[paymember_id].name}); warikan.bringPageTop('itemall.html'); }; //ページ表示時の初期処理 document.addEventListener('init', function(event) { var page = event.target; //基本情報 if (page.id == 'index') { } /*〜〜〜〜〜〜〜省略〜〜〜〜〜〜〜*/ //金額入力 else if(page.id == 'itemadd') { //修正呼び出し時 ★このあたりの記述があやしいと踏んでいる if(page.data.itemList != null) { console.log("修正呼び出し"); document.getElementById("item").value = page.data.itemList.item; document.getElementById("cost").value = page.data.itemList.cost; document.getElementById("paymember").value = page.data.itemList.paymember_id; //非表示コントロール document.getElementById("rowindex").value = page.data.rowindex; } } }); </script> <!--一覧画面--> <ons-template id="itemall.html"> <ons-page id="itemall"> <div id="wrapper"> <h1 id="h1">内訳一覧</h1> <ons-list> <ons-list-item class="item_detail" modifier="chevron" ng-repeat="x in itemize" ng-click="showItem($index)"> <p class="item_name">{{x.item}}</p> <p class="item_price">{{x.cost}}</p> <p class="item_payuser">{{x.paymember_name}}さんが支払いました</p> </ons-list-item> </ons-list> </div> </ons-page> </ons-template> <!--詳細画面--> <ons-template id="itemadd.html"> <ons-page id="itemadd"> <div id="wrapper"> <h1 id="h1">金額入力</h1> <div id="form"> <div class="form-group"> <label for="name">品名</label> <form> <input type="text" class="hoge" id="item" placeholder="レンタカー、宿代など" ng-model="item"/> </form> </div> <div class="form-group"> <label for="name">金額</label> <form> <input type="text" class="hoge" id="cost" placeholder="1000円" ng-model="cost"/> </form> </div> <div class="form-group"> <label for="number">支払いをした人</label> <ons-select id="paymember" class="select_design" ng-model="paymember" > <option ng-repeat="member in members" value="{{member.id}}" ng-selected="{{member.id == paymember}}">{{member.name}}</option> </ons-select> <form> <input type="text" class="hoge" id="rowindex" ng-model="rowindex" hidden="true"/> </form> </div> </div> <div class="btn_main"> <ons-button ng-click="addItem(item,cost,paymember,rowindex)">追加する</ons-button> </div> </div> </ons-page> </ons-template>

試したこと

ng-modelで設定した値をng-clickで引数として利用しているのですが、呼び出し→何もせずに登録時にはこの引数がundefinedとなってしまいます。

$scope.addItemに渡されている引数を確認したところ、詳細画面に呼び出したデータを修正(金額を1000から2000に変更する等)して登録すると、変更されたデータのみ値が取得でき、それ以外はundefinedでした。

修正呼び出し時の値セットの方法が悪いのかと思うのですが、改修方法について見当が付かないため質問した次第です。

何かお気づきの箇所等あればご教授頂ければと思います。

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

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

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

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

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

guest

回答1

0

自己解決

やはりdocument.getElementById
を使用した方法だと、コントロールへの値のセットがうまくいきませんでした。
そこで画面表示用のスコープを定義して、画面呼び出し時に値をセットしてやる方法で実装できました。

//金額入力画面の初期化 $scope.disp.item = ''; $scope.disp.cost = ''; //showItemメソッドを下記のように変更 $scope.showItem = function(index){ var itemList = $scope.itemize[index]; $scope.disp.item = itemList.item; $scope.disp.cost = itemList.cost; //以下略 }

HTMLはng-modelで該当のスコープを指定

<input type="text" class="hoge" id="item" placeholder="レンタカー、宿代など" ng-model="disp.item" />

これで雰囲気できました!

投稿2018/06/03 09:17

kokegreen

総合スコア7

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問