为什么 ng-init 中设置的变量在 AngularJS 的 $scope 中未定义? [英] Why is the variable set in ng-init undefined in $scope in AngularJS?

查看:17
本文介绍了为什么 ng-init 中设置的变量在 AngularJS 的 $scope 中未定义?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在视图中使用 ng-init 设置了一个变量,然后我试图在我的控制器中访问它.然而,当我尝试访问它时,我得到一个 undefined.

相关代码:

我的观点:

<div ng-init="pageTitle = '小猫'">

我的控制器:

var MyCtrl;MyCtrl = 函数($scope){返回 console.log($scope.pageTitle);};

JSFiddle

我在这里遗漏了什么?

解决方案

等待变量初始化.

$scope.$watch('pageTitle', function () {console.log($scope.pageTitle);});

I have a variable I'm setting in my view with ng-init which I am then trying to access in my controller. When I try to access it however, I'm getting an undefined.

Relevant pieces of code:

My view:

<div ng-controller="MyCtrl">
  <div ng-init="pageTitle = 'kittens'">
  </div>
</div>

My controller:

var MyCtrl;

MyCtrl = function($scope) {
  return console.log($scope.pageTitle);
};

JSFiddle

What am I missing here?

解决方案

Wait until the variable is init.

$scope.$watch('pageTitle', function () {
    console.log($scope.pageTitle); 
});

这篇关于为什么 ng-init 中设置的变量在 AngularJS 的 $scope 中未定义?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆