如何使用ng-bind捕获ng-model?

时间:2015-02-21 01:44:48

标签: angularjs calendar widget ng-bind

我无法使ng-bind="data1"从小部件中捕获输入ng-model="data1"。通过单击并选择日期,ng-bind未捕获所选日期。

<!DOCTYPE HTML>
<html>
<head>
<link rel="stylesheet" type="text/css" media="screen" href="http://tarruda.github.com/bootstrap-datetimepicker/assets/css/bootstrap-datetimepicker.min.css">
<script src= "http://ajax.googleapis.com/ajax/libs/angularjs/1.2.27/angular.min.js"></script>
<script type="text/javascript" src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.2/js/bootstrap.min.js"></script>
<script type="text/javascript" src="http://tarruda.github.com/bootstrap-datetimepicker/assets/js/bootstrap-datetimepicker.min.js"></script>
<script type="text/javascript" src="http://tarruda.github.com/bootstrap-datetimepicker/assets/js/bootstrap-datetimepicker.pt-BR.js"></script>
<script type="text/javascript">
    var Module = angular.module('myapp', []);
    myApp.directive('myapp', function datetimepicker() {
        return {
            restrict: 'A',
            require: 'ngModel',
            link: function(scope, element, attrs, ngModel) {
                element.datetimepicker({
                        minView: 2,
                        autoclose: true,
                        language: 'pt',
                        format: 'dd/mm/yyyy',
                        showMeridian: true,
                        startView: 2
                    })
                    .find('input')
                    .addClass("form-control");
            }
        };
    });
</script>
</head>
<body ng-app="myapp">
  <div id="datetimepicker" class="input-append date" ng-model="data1">
     <input ng-model="data1" type="text" datetimepicker></input>
     <p ng-bind="data1">
     <span class="add-on">
        <i data-time-icon="icon-time" data-date-icon="icon-calendar"></i>
     </span>
 </div>
</body>
</html>

1 个答案:

答案 0 :(得分:0)

您不应该为您的模块和指令指定相同的名称myapp

您的html中没有使用该指令。

另外,<div>不能有ng-model指令,所以这一行是错误的:

<div id="datetimepicker" class="input-append date" ng-model="data1">

您的问题是您需要在控制器中初始化data1

function($scope) {
  // Initialization
  $scope.data1 = '';
}