c# – 使用TempData在控制器操作之间传递细节不好吗?
发布时间:2020-12-15 17:20:33 所属栏目:百科 来源:网络整理
导读:我有某些情况需要在控制器操作之间传递一个值. 将returnUrl从视图传递到所有嵌套视图时.在里面 我有 @{ TempData["returnURL"] = Request.Url.AbsoluteUri;} 然后以类似的方式访问它(在我的真实版本中我 检查密钥是否在TempData中,并且returnURL是真实的 网
我有某些情况需要在控制器操作之间传递一个值.
>将returnUrl从视图传递到所有嵌套视图时.在里面 @{ TempData["returnURL"] = Request.Url.AbsoluteUri; } 然后以类似的方式访问它(在我的真实版本中我 return Redirect(TempData["returnURL"].ToString()); 如果它需要继续第一页更改(即搜索 TempData["returnURL"] = TempData["returnURL"]; >当我需要从一个控制器动作传递一个值到一个 public ViewResult Index(FormCollection form) { var model = new GridColumnChooserViewModel(); //Select deleted/not deleted rows if (form.HasKeys()) model.ShowRows = (form["deletedDropDown"] == null) ? "Active" : GetOptionByName(form["deletedDropDown"]); TempData["ShowRows"] = model.ShowRows; ... } 然后在我的另一个ajax调用的动作控制器中我访问它: public JsonResult GetData() { //Select deleted/not deleted rows var showRows = (TempData.ContainsKey("ShowRows") && TempData["ShowRows"] == null) ? "Active" : GetOptionByName(TempData["ShowRows"].ToString()); //refresh tempdata showrows so it is there for next call TempData["ShowRows"] = model.ShowRows; return this.GetDataSource(showRows); } 我的问题是,这是非常糟糕的做法吗?根据我对它的理解,我基本上使用TempData就像一个会话cookie.有没有更好的方法来实现这一点,比如使用实际的cookie? 解决方法
是的,我会说这通常是不好的做法.虽然ViewData字典方法快速且相当容易实现,但它可能导致拼写错误和编译时未捕获的错误.另一种方法是使用ViewModel模式,该模式允许您为需要公开其中的值或内容的特定视图使用强类型类.最终为您提供类型安全和编译时间检查以及intellisense.
我的第一选择是使用视图模型.如果这不适合,那么使用会话状态可能就好了. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |