発生している現象
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でした。
修正呼び出し時の値セットの方法が悪いのかと思うのですが、改修方法について見当が付かないため質問した次第です。
何かお気づきの箇所等あればご教授頂ければと思います。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。