首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >敲除ajax.beginform回调

敲除ajax.beginform回调
EN

Stack Overflow用户
提问于 2014-04-30 09:41:37
回答 2查看 612关注 0票数 1

我在表中使用了一个可观察到的敲除数组,每一行都有一个删除按钮包装在一个MVC Razor Ajax.BeginForm中。

delete按钮调用javascript函数,该函数执行一个ko.utils.postJson,将id发送到服务器,以便在服务器上删除记录,然后从viewModel中删除,从而更新UI。

如何才能在执行客户端删除之前等待postJson?如果我使用OnSuccess和OnFailure选项的Ajax.BeginForm -如何从数组中删除相关的$data?

remove函数有一个引用传入,但是如果我先做服务器端,如何将此引用传递给OnSuccess回调?

我知道我自己可能会在remove函数中编写一个.ajax调用,但如果它能工作的话,我更愿意使用Ajax.BeginForm。

谢谢菲尔

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-04-30 15:43:12

Djbielejeski提出了一种很好的方法,但是如果您仍然希望使用Ajax.BeginForm来删除,也可以将参数传递给OnSuccess方法。

只需将id传递给您的OnSuccess方法即可。就像这样:

代码语言:javascript
复制
@using(Ajax.BeginForm("action", "controller", new AjaxOptions { OnSuccess = string.Format("OnSuccess({0})", rowId) }) { ... your html ... })

上面的代码假设rowId是一个整数,如果它是guid或必须用引号'‘包装的字符串。

在OnSuccess函数中,您将获得允许从可观察数组中移除元素的id。

代码语言:javascript
复制
function OnSuccess(id){
  // id is available here... and you can get your viewmodel with ko.dataFor function
}
票数 1
EN

Stack Overflow用户

发布于 2014-04-30 12:15:04

将删除函数连接到项目的父级。

例如,你可以这样做

Javascript

代码语言:javascript
复制
var itemObject = function(data){
    var self = this;

    this.Id = ko.observable(data.Id);
    .... etc ....
};

var baseViewModel = function(){
    var self = this;

    this.Items = ko.observableArray();

    this.Setup = function(items){
        //using underscore.js to map the items
        self.Items(_.map(items, function(item){
            return new itemObject(item);
        }));
    };

    this.deleteItem = function(item){
        $.ajax({
            url: "/api/v1/Item/" + item.Id(),
            type: "DELETE",
            success: function (data) {
                //Client side remove here
            },
            error: function (data) {
                //Whoops error time
            },
            complete: function (data) {
                //Turn of spinners or whatever here
            }
        });
    };
};

$(function(){
  var myApp = new baseViewModel();
  myApp.Setup(items);
  ko.applyBindings(myApp);
});

Html

代码语言:javascript
复制
<div data-bind="foreach: Items">
    <div data-bind="text: Id"></div>
    <button data-bind="click: $parent.deleteItem">Delete</button>
</div>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23384675

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档