簡體   English   中英

成功后,fetch上的更新未更新ribs.js模型

[英]backbone.js model not updating on fetch after success

我正在嘗試在項目中使用bone.js,在嘗試使用fetch方法更新模型時遇到了麻煩。 我的模型如下(單個對象,因為我只想要一個實例)

 define([
'underscore',
'backbone'
], function (_, Backbone) {

var UserModel = Backbone.Model.extend({
    defaults: {
        name: "",
        loggedIn: false,
        user: "null",
        pass: "null"
    },

    prepare: function (options) {
        this.loggedIn = false;
        this.user = options.user;
        this.pass = options.pass;
    },

    url: function () {
        return _SERVER_ + "/WebServices/TTMobileAppService.svc/getUserLogin?user=" + this.user+"&pass="+this.pass;
    },

    parse: function (res) {
        // because of jsonp 
        return res.data;
    }

});

return new UserModel();

});

我的看法如下所示,當成功獲取數據時,將在模型和響應記錄的地方調用updateLogin方法。

define([(jquery,'underscore','backbone','models / user / UserModel','text!templates / login / loginTemplate.html'],函數($,_,Backbone,UserModel,loginTemplate){/ /},footerTemplate){

var LoginView = Backbone.View.extend({
    el: $("#loginArea"),
    events: {
        'mouseup #loginButton': 'expandLogin',
        'click #login': 'loginUser'
    },
    initialize: function () {
        this.options = { user: '', pass: "" };
        var that = this;
        this.model = UserModel;
        this.model.on('change', this.render, this);
        this.render();
    },
    render: function () {
        var data = {
            user: this.model.toJSON(),
            _: _
        };
        var compiledTemplate = _.template(loginTemplate, data);
        this.$el.html(compiledTemplate);
    },
    updateLogin: function(model, response, options) {
        console.log(model);
        console.log(response);
        console.log(options);
    },
    expandLogin: function () {
        var button = this.$el.children("div").first().children('#loginButton')[0];
        var box = this.$el.children("div").first().children('#loginBox')[0];
        $(box).fadeToggle(400);
        $(button).toggleClass('active');
    },
    loginUser: function () {
        var that = this;
        var username = $('#username_field', this.el).val();
        var password = $('#password_field', this.el).val();
        this.options = { user: username, pass: password };
        this.model.prepare(this.options);
        this.model.fetch({
            type: "GET",
            error: function (collection, response, options) {
                alert('error');
                alert(response.responseText);
            },
            success: that.updateLogin,
            complete: function () {
                alert('complete');
            },
            dataType: 'jsonp'
        });

    }

});

return LoginView;

});

目前我的模型尚未更新

螢火蟲模型 但響應對象正確且成功 jsonp對象返回正常

任何幫助將不勝感激

 parse: function (res) {
    // because of jsonp 
    return res.data;
}

需要刪除,它是從示例中復制的,盡管示例中的查詢在對象內部有一個對象,這與我的配置不同。 現在解決=]

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM