SharePoint:扩展DVWP - 第5部分:在保存操作提交前做些事情——PreSaveAction()

有时用户会在我们设想的顺序之前点击确定。不管是需要在保存数据前先进行验证,还是要抓一些其他的信息,或者是创建一个通知让用户知道一些事情,都可以利用SharePoint的一个内置功能,该功能允许我们在保存信息被提交前截取确认按钮的点击事件。

事实上,我们甚至可以在标准的默认列表表单(类似NewItem.aspx等等)上使用该功能,除非你根本就不打算进入编辑状态。

PreSaveAction()

在SharePoint里默认的保存(或确定)按钮会在进行其他操作前首先调用PreSaveAction(),它是个空函数。所以,我们可以利用它来在列表项保存之前做些事情,甚至如果需要的话可以阻止其保存。

只需简单的将PreSaveAction()Javascript函数添加到页面上的一个内容编辑器WebPart (简称CEWP)里即可。如下:

1
2
3
4
5
6
7
8
<script language="javascript" type="text/javascript">
function PreSaveAction() {
    // 做一些事情 - 在接下来的博文中,你将看到建议在这里做的事
    return true; //如果事情进展顺利…
    //或
    return false; // 如果事情进行的有问题…
}
</script>

在DVWP中使用PreSaveAction()

如果你一直关注扩展DVWP系列的话,一定很关心这个功能在DVWP中该怎么使用。在一个DVWP的列表表单操作中,不会调用PreSaveAction(),但是我们可以让它去调用,同样也很简单。

若要从一个表单操作链接中调用PreSaveAction(),只需在GenFireServerEvent调用前添加一个到它调用即可。

即,从原来的:

1
<a href="javascript: {ddwrt:GenFireServerEvent('__commit')}">保存文件</a>

变成:

1
<a href="javascript: if(PreSaveAction()) {ddwrt:GenFireServerEvent('__commit')}">保存文件</a>

通过把该调用放置在if条件里,我们可以确保当我们不想后面的部分运行时就不会运行。也就是说,我们实现了与开箱即用的确定按钮同样的功能。

运行效果

最极端的一个实验,如果将PreSaveAction()写成下面这样:

1
2
3
4
5
function PreSaveAction()
{
    alert("不允许修改!");
    return false;
}

就可以从页面层次阻止用户对列表数据的修改了。以下是在EditForm.aspx中点击“确定”按钮的运行效果:

在数据视图Web部件中点击“保存文件”链接时的运行效果:

 

下一篇中:我们将讨论如果在DVWP的列表表单操作中使用工作流。

 

参考资料

SharePoint: Extending the DVWP – Part 5: Doing Stuff Before Save on Submit – PreSaveAction()

posted @   Sunmoonfire  阅读(2222)  评论(1编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示