今天被人问到:在MOSS中,有一个列表,我们希望根据用的特征动态切换内容显示。这个筛选条件很复杂,我们没有办法直接使用视图的筛选来实现。应该怎麽办呢?
我的解决方案如下:
第一步:webpart的部分
using System;
using System.Runtime.InteropServices;
using System.Web.UI;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Serialization;
using Microsoft.SharePoint;
using Microsoft.SharePoint.WebControls;
using Microsoft.SharePoint.WebPartPages;
using System.Web;
namespace SPViewPart
{
[Guid("3179933a-c04a-432d-a6f6-4e9e41cac3f2")]
public class SPViewPart : System.Web.UI.WebControls.WebParts.WebPart
{
public SPViewPart()
{
this.ExportMode = WebPartExportMode.All;
}
protected override void Render(HtmlTextWriter writer)
{
// TODO: add custom rendering code here.
SPWeb web = SPContext.Current.Web;
SPList list = web.Lists["任务"];
SPView view = list.Views["所有任务"];
writer.Write(HttpUtility.HtmlEncode(view.Query));//这里只是为了调试,显示出来这个内容,完全可以不显示的
}
protected override void OnInit(EventArgs e)
{
SPWeb web = SPContext.Current.Web;
web.AllowUnsafeUpdates = true;
SPList list = web.Lists["任务"];
SPView view = list.Views["所有任务"];
string query = "<OrderBy><FieldRef Name=\"ID\" /></OrderBy><Where><Eq><FieldRef Name=\"Title\" /><Value Type=\"Text\">王磊</Value></Eq></Where>";//我这里是直接写死的,你可以动态构造这一串东西
view.Query = query;
view.Update();
list.Update();
}
}
}
第二步:来看网站。现在只有王磊的记录
然后,我去修改代码,改成“陈希章”
string query = "<OrderBy><FieldRef Name=\"ID\" /></OrderBy><Where><Eq><FieldRef Name=\"Title\" /><Value Type=\"Text\">陈希章</Value></Eq></Where>";
再部署,即看到它已经改掉了
以上只是一个范例,实际上我也觉得这种修改视图定义的方法是简单粗暴的。但目前也没有更好的办法。
我觉得如果List上面可以有接口让我们扩展的话,那就更好了