Ionic AngularJS Radio Group 使用 ion-radio 的 ng-model 问题

Ionic AngularJS Radio Group ng-model issue using ion-radio

我无法使用 AngularJS 1.4.7 和 Ionic 1.1.1 检索无线电组的值;

任何想法都很好,谢谢。

查看问题的代码笔片段:http://codepen.io/angsar/pen/RWdvrO

HTML

<html ng-app="app">
    <head>
        <link rel="stylesheet" href="http://code.ionicframework.com/1.1.1/css/ionic.min.css" />
        <link href="http://code.ionicframework.com/ionicons/1.5.2/css/ionicons.min.css" rel="stylesheet">
        <script src="http://code.ionicframework.com/1.1.1/js/ionic.bundle.js"></script>
    </head>
    <body ng-controller="myCtrl">    
        <ion-content padding="true">

            <form class="list" ng-submit="Pass(test)">
                <p>Selected Sample: {{test.val}}</p>
                <ion-radio ng-model="test.val" ng-value="s1">Sample 1</ion-radio>
                <ion-radio ng-model="test.val" ng-value="s2">Sample 2</ion-radio>
                <button class="button button-energized button-large icon-right button-full">Test</button>
            </form>

        </ion-content>      
    </body>
</html>

Javascript

angular.module('app', ['ionic'])
.controller('myCtrl', function($scope) {
  $scope.Pass = function($test) {
    alert("Test: "+$test.val);
  }  
});

尝试以下操作:

angular.module('app', ['ionic'])
.controller('myCtrl', function($scope) {
 $scope.test = {};
 $scope.Pass = function($test) {
   alert("Test: "+ $scole.test.val);
 }  
});

解释:

  1. $test 未在您的 $scope 中定义。
  2. $开头的变量在angular中有特殊含义,所以你不应该将它们用作常规变量名

更新: 在双引号 ng-value

中单引号字符串值也很重要
<ion-radio ng-model="test.val" ng-value="'s1'">Sample 1</ion-radio>

在阅读 "accepted answer" post 之前,我已经设法解决了它。 请参阅下面我提出的解决方案。

我用 value 替换了 ng-value,用 test 替换了 test.val。

http://codepen.io/angsar/pen/LpvGzj

angular.module('app', ['ionic'])
.controller('myCtrl', function($scope) {

  $scope.Pass = function($test) {
    alert("Test: "+$test);
  }; //pass  

});

尝试以下操作,

html:

<form class="list" ng-init="test={}" ng-submit="Pass(test)">

angular.js

angular.module('app', ['ionic'])
.controller('myCtrl', function($scope) {
  $scope.Pass = function(test) {
     alert("Test: "+test.val);
  }
});

codepen: http://codepen.io/mohanapriya/pen/BzpzZx?editors=1010