微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

当使用AngularJS HotTowel中的vm“ControllerAs”语法时,从单元测试文件访问$scope

参见这里例如: http://www.johnpapa.net/angularjss-controller-as-and-the-vm-variable/

正如标题所示,我遵循本教程[http://tech.pro/tutorial/1473/getting-started-with-angularjs-unit-testing]设置单元测试,一切都很好,除了事实,我似乎不能访问vm变量作为我的$范围。

仪表板

var controllerId = 'dashboard';
angular.module('app')
    .controller(controllerId,['common','datacontext',dashboard]);


function dashboard(common,datacontext) {
    var getLogFn = common.logger.getLogFn;
    var log = getLogFn(controllerId);

    var vm = this;      
    vm.title = 'Dashboard';

dashboard.Spec.js

describe("app module",function() {
    beforeEach(module("app"));

    describe("dashboard",function() {
        var scope,controller;

        beforeEach(inject(function($rootScope,$controller) {
            scope = $rootScope.$new();
            controller = $controller;
        }));

        it("should assign Dashboard as title",function() {
            controller("dashboard",{
                $scope: scope
            });
            expect(scope.title).toBe("Dashboard");
        });
    });
});

我试过的:它工作(测试通过),当我命名’$ scope’直接在控制器依赖和设置“title”属性。但是,我想保持这个模式。

我还尝试直接在依赖关系中传递$ scope,并将控制器参数命名为“vm”…

Karmas失败的测试消息是:预期未定义为“Dashboard”

欣赏任何帮助!

啊,显然现在…我可以通过引用在测试中创建的控制器访问vm变量:
it("should assign Dashboard as title",function () {
       var vm = controller("dashboard",{ $scope: scope });
       expect(vm.title).toBe("Dashboard");
    });

原文地址:https://www.jb51.cc/angularjs/145668.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐