繁体   English   中英

淘汰赛无容器foreach不起作用

[英]knockout containerless foreach not working

我一定想念一些东西,所以请告诉我。
我正在使用Knockout 3.4.2

我所有其他的绑定都在工作,但是foreach却没有运行。 我想念什么吗?

我的PageViewModel:

export class UserManagementViewModel implements IPageViewModel {
        userApi: AjAxConnection<any>;
        listOfUsers: KnockoutObservableArray<IUser>;
        isLoading: KnockoutObservable<boolean>;
        currentPage: KnockoutObservable<number>;
        totalPages: KnockoutObservable<number>;
        totalCount: KnockoutObservable<number>;
        totalRecordsPerPage: KnockoutObservable<number>;

        // New User
        newUserEmail: KnockoutObservable<string>;
        newUserFirstName: KnockoutObservable<string>;
        newUserLastName: KnockoutObservable<string>;
        newUserValidation: KnockoutValidationGroup;

        constructor() {
            this.userApi = new AjAxConnection("api/user");
            this.listOfUsers = ko.observableArray([]);
            this.isLoading = ko.observable(false);
            this.currentPage = ko.observable(0);
            this.totalPages = ko.observable(0);
            this.totalCount = ko.observable(0);
            this.totalRecordsPerPage = ko.observable(10);

            this.newUserEmail = ko.observable("").extend({
                required: {message: "Email Address is required."}
            });
            this.newUserFirstName = ko.observable("").extend({
                required: {message: "First Name is required."}
            });
            this.newUserLastName = ko.observable("").extend({
                required: {message: "Last Name is required."}
            });

            this.newUserValidation = ko.validatedObservable({
                email: this.newUserEmail(),
                firstName: this.newUserFirstName(),
                lastName: this.newUserLastName()
            });

        }

        init(): void {
            this.updateUserList();
        }

        updateUserList(): void {
            this.isLoading(true);
            this.userApi.get("?page=" + this.currentPage() + "&totalPerPage=" + this.totalRecordsPerPage(),
                    ContentTypes.json)
                .done((data: IPagableResourceModel<IUser>) => {
                    console.log(data);
                    if (data.isSuccessful) {
                        this.listOfUsers().push(data.results);
                    } else {

                    }
                }).always(() => {
                    this.isLoading(false);
                });
        }

        openNewUserModal(): void {
            $("#newUserModal").modal("show");
        }

        cancelNewUserModal(): void {
            this.closeNewUserModal();
            this.clearNewUserDetails();
        }

        createNewUser(): void {
            if (this.newUserValidation.isValid()) {
                this.userApi.post("",
                    {
                        "firstName": this.newUserFirstName(),
                        "lastName": this.newUserLastName(),
                        "userName": this.newUserEmail()
                    },
                    ContentTypes.json);
            }
        }

        private closeNewUserModal(): void {
            $("#newUserModal").modal("hide");
        }

        private clearNewUserDetails(): void {
            this.newUserEmail("");
            this.newUserFirstName("");
            this.newUserLastName("");
        }
    }

IUser是基本的:

export interface IUser {
    id: string;
    firstName: string;
    lastName: string;
    userName: string;
}

最后是我的观点:

<div id="Users" class="tab-pane active">
    <h3>Users</h3>
    <div class="container">
        <div class="row">
            <div class="col-md-2">Id</div>
            <div class="col-md-2">UserName</div>
            <div class="col-md-2">FullName</div>
            <div class="col-md-2">Organization</div>
            <div class="col-md-2">Clinic</div>
            <div class="col-md-2">Options</div>
        </div>
        <div class="row" data-bind="visible: isLoading()">
            <div class="col-md-12 text-center">
                <img src="~/images/loading.gif" alt="Loading" />
                <br />
                Please wait, loading...
            </div>
        </div>
        <div class="row" data-bind="visible: !isLoading() && listOfUsers().length == 0">
            <div class="col-md-12 text-center">
                No Users Found.
            </div>
        </div>
        <div data-bind="visible: !isLoading() && listOfUsers().length != 0">
            <!--ko foreach: listOfUsers-->
            <div class="row">
                <div class="col-md-2"><!--ko text: id--><!--/ko--></div>
                <div class="col-md-2"><!--ko text: userName--><!--/ko--></div>
                <div class="col-md-2"></div>
                <div class="col-md-2"></div>
                <div class="col-md-2"></div>
                <div class="col-md-2">[OPTIONS GO HERE]</div>
            </div>
            <!--/ko-->
        </div>
    </div>
</div>

渲染的HTML和Knockout上下文: html和敲除上下文

显示API调用的控制台: 安慰

我终于发现了自己的错误,但同时又很小但很严重。

在我的PageViewModel中使用它之前:

    updateUserList(): void {
        this.isLoading(true);
        this.userApi.get("?page=" + this.currentPage() + "&totalPerPage=" + this.totalRecordsPerPage(),
                ContentTypes.json)
            .done((data: IPagableResourceModel<IUser>) => {
                console.log(data);
                if (data.isSuccessful) {
                    this.listOfUsers().push(data.results);
                } else {

                }
            }).always(() => {
                this.isLoading(false);
            });
    }

我不得不将其更改为:

    updateUserList(): void {
        this.isLoading(true);
        this.userApi.get("?page=" + this.currentPage() + "&totalPerPage=" + this.totalRecordsPerPage(),
                ContentTypes.json)
            .done((data: IPagableResourceModel<IUser[]>) => {
                console.log(data);
                if (data.isSuccessful) {
                    this.listOfUsers().push(data.results);
                } else {

                }
            }).always(() => {
                this.isLoading(false);
            });
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM