骨干Subview事件未触发

蜜雪儿

我在Backbone中有一个视图,其中包含许多子视图。子视图的事件没有触发,我很难理解为什么。我一直在遵循一个教程,该教程显示了如何触发子视图的事件:

https://ianstormtaylor.com/rendering-views-in-backbonejs-isnt-always-simple

以下是代码的相关部分:

var TaskView = Backbone.View.extend({
    tagName: "div",
    template: _.template($("#taskAddTemplate").html()),
    render: function () {
        // append the template to the element
        this.$el.append(this.template);

        var scheduleData = new ScheduleModel(this.model.attributes.Schedule);
        this.Schedule = new ScheduleView({ model: scheduleData });
        this.assign(this.Schedule, "#ScheduleDetails");
        return this;
    },
    assign: function(view, selector) {
        view.setElement(this.$(selector)).render();
    },
    events: {
        "submit #NewTaskForm": function (e) {
            e.preventDefault();

            $("#SaveTaskButton").effect("pulsate", { times: 0 }, 0);
            console.log("In submit for task");
        }
    }

});

var ScheduleView = Backbone.View.extend({
    tagName: "div",
    template: _.template($("#scheduleAddTemplate").html()),
    render: function () {
        // append the template to the element
        this.$el.append(this.template(this.model.toJSON()));
        // set the schedule type
        var renderedInterval = SetScheduleType(this.model);
        // append to the interval
        $("#Interval", this.$el).append(renderedInterval.el);
        return this;
    },
    events: {
        "submit #NewTaskForm": function (e) {
            e.preventDefault();
            console.log("In submit for schedule");
        }
    }
});

视图正确显示,但是每当我单击ID为NewTaskForm的提交按钮时,都会为“任务”视图而不是“计划”视图触发该事件。我究竟做错了什么?

编辑:

以下是模板:

<script id="taskAddTemplate" type="text/html">
    <nav class="navbar navbar-default" id="TaskMenu">
        <ul class="nav navbar-nav" id="TaskTabs">
            <li role="presentation"><a href="#TaskDetails" aria-controls="Task Details" role="tab" data-toggle="tab">Task Details</a></li>
            <li role="presentation"><a href="#ScheduleDetails" aria-controls="Schedule Details" role="tab" data-toggle="tab">Schedule Details</a></li>
        </ul>
    </nav>

    <form class="form form-horizontal" id="NewTaskForm">
        <div class="tab-content">

            <div role="tabpanel" class="tab-pane" id="TaskDetails">
                <div class="form-group">
                    <label class="col-xs-2 control-label">Task Name: </label>
                    <input class="col-xs-10 form-control" type="text" id="TaskName" name="TaskName" />

                </div>
                <div class="form-group">
                    <label class="col-xs-2 control-label">Message: </label>
                    <textarea class="col-xs-10 form-control" rows="5" type="text" id="Message" name="Message"></textarea>
                </div>
            </div>

            <div role="tabpanel" class="tab-pane" id="ScheduleDetails"></div>

            <div class="form-group">
                <div class="container">
                    <div class="col-xs-2">
                        <input type="submit" class="form-control btn btn-primary col-xs-2" id="SaveTaskButton" />
                    </div>
                    <div class="col-xs-2">
                        <input type="button" class="form-control btn btn-danger col-xs-2" id="CancelNewTaskButton" value="Cancel" />
                    </div>
                </div>
            </div>
        </div>
    </form>
</script>


<script id="scheduleAddTemplate" type="text/html">
    <div id="Schedule" class="form-group">

        <div class="row">
            <div class="col-xs-3">
                <span class="col-xs-1"></span>
                <select class="form-control" id="ScheduleType" data-val="true" data-val-required="The Schedule Type Field is require.">
                    <option value="hourly">Hourly</option>
                    <option value="daily">Daily</option>
                    <option value="weekly">Weekly</option>
                    <option value="monthly">Monthly</option>
                </select>
            </div>
            <div id="Interval" class="col-xs-9"></div>

        </div>

        <div id="StartAndEnd" class="row">

            <label class="control-label col-xs-1">Start</label>
            <input type="text" class="date form-control col-xs-2" id="StartDate" value="<%= StartDate %>" />
            <input type="text" class="time form-control col-xs-1" id="StartTime" value="<%= StartTime %>" />
            <label class="control-label col-xs-1">End</label>
            <input type="text" class="date form-control col-xs-1" id="EndDate" value="<%= EndDate %>" />
            <span class="col-xs-2"></span>
        </div>
    </div>
</script>
zon7

好的,有两种方法:

第一种方式

最简单的方法将是移动NewTaskFormscheduleAddTemplate这样,该事件将在此处触发,然后您可以使用触发器触发它

events: {
    "submit #NewTaskForm": 'onSubmit'
},
onSubmit: function(ev){
    e.preventDefault();
    console.log("In submit for schedule");
    //TODO: Call the save method
    this.model.save(
        success: function(...){
            this.trigger('save')
        }
    )
}

并在TaskViewrender方法中添加它

var scheduleData = new ScheduleModel(this.model.attributes.Schedule);
this.Schedule = new ScheduleView({ model: scheduleData });
this.assign(this.Schedule, "#ScheduleDetails");
this.listenTo(this.Schedule, "save", function(...){})

第二种方式

周围的其他方法将是从调用一个方法TaskViewScheduleView由于您已经有一个存储视图的变量,因此您可以在事件方法中调用它

events: {
    "submit #NewTaskForm": function (e) {
        e.preventDefault();

        $("#SaveTaskButton").effect("pulsate", { times: 0 }, 0);
        console.log("In submit for task");
        this.Schedule.method_name()
    }
}

无论如何,由于在计划视图中没有多余的逻辑,因此不需要多余的视图,并且您可以在一个简单的视图中完成所有操作。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章