首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在编辑表单模式下的Sharepoint DataFormWebPart在自定义WebPart中使用时不保存

在编辑表单模式下的Sharepoint DataFormWebPart在自定义WebPart中使用时不保存
EN

Stack Overflow用户
提问于 2015-12-26 21:03:02
回答 1查看 1.8K关注 0票数 2

我需要为自定义sharepoint列表创建编辑表单,该列表根据用户配置文件显示/允许编辑/隐藏某些字段。因此,我创建了一个非默认的编辑表单,将其WebPartPages:DataFormWebPart复制到一个自定义的webpart解决方案中,并将其部署到sharepoint中,稍微做了一些调整(querystring参数重命名为SPID,而不是ID,因为was部件在页面库中使用,使用ID作为param会给我带来各种各样的错误)

现在这个过程对“新表单”非常有效,将数据移动到下一个屏幕.全是桃子。

我用一个编辑表单尝试了同样的过程,对XSL进行了一点定制(没有什么花哨的只是样式和HTML表的洗牌),而且当我加载页面时,我可以看到绑定正常工作,我的所有字段都有它们的值。但是当我点击保存时,它会做一些回发,所有字段都会被重置为空值,并且在检查之后,所有的值都没有被保存。

此时,为了隔离问题,我删除了所有的自定义,唯一与编辑表单页面和自定义webpart不同的是我使用的ListItemId位置,其中我将查询参数从"ID“更改为"SPID”。

在自定义的webpart中运行WebPartPages:DataFormWebPart,有什么我应该知道的吗?令人费解的是,插入表单工作,编辑表单显示所有值(绑定确定),但没有保存任何内容。

当然,错误日志没有我可以找到的跟踪,也没有JavaScript错误(即开发工具调试)。

任何指示都将不胜感激。

PS: Sharepoint 2013 on prem。PS2:这是我的for部件的标记:

代码语言:javascript
复制
    <WebPartPages:DataFormWebPart runat="server" EnableOriginalValue="False" DisplayName="New Projects" ViewFlag="8" ViewContentTypeId="" Default="FALSE"
                        ListUrl="" ListDisplayName="" ListName="{5A1F5F46-E308-440D-A7CE-3FF0587D9B4B}" ListId="5a1f5f46-e308-440d-a7ce-3ff0587d9b4b" PageType="PAGE_EDITFORM"
                        PageSize="-1" UseSQLDataSourcePaging="True" DataSourceID="" ShowWithSampleData="False" AsyncRefresh="False" ManualRefresh="False" AutoRefresh="False"
                        AutoRefreshInterval="60" NoDefaultStyle="TRUE" InitialAsyncDataFetch="False" Title="New Projects" FrameType="None" SuppressWebPartChrome="False"
                        Description="" IsIncluded="True" PartOrder="2" FrameState="Normal" AllowRemove="True" AllowZoneChange="True" AllowMinimize="True" AllowConnect="True"
                        AllowEdit="True" AllowHide="True" IsVisible="True" DetailLink="" HelpLink="" HelpMode="Modeless" Dir="Default" PartImageSmall=""
                        MissingAssembly="Cannot import this Web Part." PartImageLarge="" IsIncludedFilter="" ExportControlledProperties="True"
                        ConnectionID="00000000-0000-0000-0000-000000000000" ID="Project_DataFormWebPart" ChromeType="None" ExportMode="All" __MarkupType="vsattributemarkup"
                        __WebPartId="{C30D3C9F-ECB9-4334-B442-5244C9837488}" __AllowXSLTEditing="true" WebPart="true" Height="" Width="" >
                        <DataSources>
                            <SharePoint:SPDataSource ID="Project_DataSource" runat="server" DataSourceMode="ListItem"
                                SelectCommand = "&lt;View&gt;&lt;Query&gt;&lt;Where&gt;&lt;And&gt;&lt;Eq&gt;&lt;FieldRef Name=&quot;ContentType&quot;/&gt;&lt;Value Type=&quot;Text&quot;&gt;Item&lt;/Value&gt;&lt;/Eq&gt;&lt;Eq&gt;&lt;FieldRef Name=&quot;ID&quot;/&gt;&lt;Value Type=&quot;Number&quot;&gt;{ListItemId}&lt;/Value&gt;&lt;/Eq&gt;&lt;/And&gt;&lt;/Where&gt;&lt;/Query&gt;&lt;/View&gt;"
                                UseInternalName="True" UseServerDataFormat="True">
                                <SelectParameters>
                                    <WebPartPages:DataFormParameter ParameterKey="ListItemId" PropertyName="ParameterValues" DefaultValue="0" Name="ListItemId"></WebPartPages:DataFormParameter>
                                    <WebPartPages:DataFormParameter ParameterKey="weburl" PropertyName="ParameterValues" DefaultValue="http://jam3iya4" Name="weburl"></WebPartPages:DataFormParameter>
                                    <WebPartPages:DataFormParameter ParameterKey="ListID" PropertyName="ParameterValues" DefaultValue="{5A1F5F46-E308-440D-A7CE-3FF0587D9B4B}" Name="ListID"></WebPartPages:DataFormParameter>
                                </SelectParameters>
                                <UpdateParameters>
                                    <WebPartPages:DataFormParameter ParameterKey="ListItemId" PropertyName="ParameterValues" DefaultValue="0" Name="ListItemId"></WebPartPages:DataFormParameter>
                                    <WebPartPages:DataFormParameter ParameterKey="weburl" PropertyName="ParameterValues" DefaultValue="http://jam3iya4" Name="weburl"></WebPartPages:DataFormParameter>
                                    <WebPartPages:DataFormParameter ParameterKey="ListID" PropertyName="ParameterValues" DefaultValue="{5A1F5F46-E308-440D-A7CE-3FF0587D9B4B}" Name="ListID"></WebPartPages:DataFormParameter>
                                </UpdateParameters>
                            </SharePoint:SPDataSource>
                        </DataSources>
                        <Xsl>
                            <xsl:stylesheet xmlns:x="http://www.w3.org/2001/XMLSchema" xmlns:dsp="http://schemas.microsoft.com/sharepoint/dsp" version="1.0" exclude-result-prefixes="xsl msxsl ddwrt" xmlns:ddwrt="http://schemas.microsoft.com/WebParts/v2/DataView/runtime" xmlns:asp="http://schemas.microsoft.com/ASPNET/20" xmlns:__designer="http://schemas.microsoft.com/WebParts/v2/DataView/designer" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" xmlns:SharePoint="Microsoft.SharePoint.WebControls" xmlns:ddwrt2="urn:frontpage:internal">
                                <xsl:output method="html" indent="no"/>
                                <xsl:decimal-format NaN=""/>
                                <xsl:param name="ListItemId"></xsl:param>
                                <xsl:param name="dvt_apos">&apos;</xsl:param>
                                <xsl:param name="ManualRefresh"></xsl:param>
                                <xsl:variable name="dvt_1_automode">0</xsl:variable>
                                <xsl:template match="/" xmlns:x="http://www.w3.org/2001/XMLSchema" xmlns:dsp="http://schemas.microsoft.com/sharepoint/dsp" xmlns:asp="http://schemas.microsoft.com/ASPNET/20" xmlns:__designer="http://schemas.microsoft.com/WebParts/v2/DataView/designer" xmlns:SharePoint="Microsoft.SharePoint.WebControls">
                                    <xsl:choose>
                                        <xsl:when test="($ManualRefresh = 'True')">
                                            <table width="100%" border="0" cellpadding="0" cellspacing="0">
                                                <tr>
                                                    <td valign="top">
                                                        <xsl:call-template name="dvt_1"/>
                                                    </td>
                                                    <td width="1%" class="ms-vb" valign="top">
                                                        <img src="/_layouts/15/images/staticrefresh.gif" id="ManualRefresh" border="0" onclick="javascript: {ddwrt:GenFireServerEvent('__cancel')}" alt="Click here to refresh the dataview."/>
                                                    </td>
                                                </tr>
                                            </table>
                                        </xsl:when>
                                        <xsl:otherwise>
                                            <xsl:call-template name="dvt_1"/>
                                        </xsl:otherwise>
                                    </xsl:choose>
                                </xsl:template>
                                <xsl:template name="dvt_1">
                                    <xsl:variable name="dvt_StyleName">ListForm</xsl:variable>
                                    <xsl:variable name="Rows" select="/dsQueryResponse/Rows/Row[@ID=$ListItemId]"/>
                                    <div>
                                        <span id="part1">
                                            <table cellpadding="4" cellspacing="0" border="0">
                                            <caption style="color:red;">{{<xsl:value-of select="$ListItemId"/>}}</caption>
                                                <tr>             
                                                    <td class="ms-vh">
                                                    <table border="0" width="100%">
                                                        <xsl:call-template name="dvt_1.body">
                                                            <xsl:with-param name="Rows" select="$Rows"/>
                                                        </xsl:call-template>
                                                    </table>                        
                                                    </td>
                                                </tr>
                                            </table>
                                        </span>
                                        <SharePoint:AttachmentUpload runat="server" ControlMode="Edit"/>
                                        <SharePoint:ItemHiddenVersion runat="server" ControlMode="Edit"/>
                                    </div>
                                </xsl:template>
                                <xsl:template name="dvt_1.body">
                                    <xsl:param name="Rows"/>
                                    <tr>
                                        <td class="ms-toolbar" nowrap="nowrap">
                                            <table>
                                                <tr>
                                                    <td width="99%" class="ms-toolbar" nowrap="nowrap"><IMG SRC="/_layouts/15/images/blank.gif" width="1" height="18"/></td>
                                                    <td class="ms-toolbar" nowrap="nowrap">
                                                        <SharePoint:SaveButton runat="server" ControlMode="Edit" id="savebutton1"/>
                                                        <input type="button" value=" Ok " name="btnTopSave" onclick="javascript:{ddwrt:GenFireServerEvent('__commit')}" style="height:22px"/>
                                                    </td>
                                                </tr>
                                            </table>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td class="ms-toolbar" nowrap="nowrap">
                                            <SharePoint:ItemValidationFailedMessage runat="server" ControlMode="Edit"/>
                                        </td>
                                    </tr>
                                    <xsl:for-each select="$Rows">
                                        <xsl:call-template name="dvt_1.rowedit"/>
                                    </xsl:for-each>
                                    <tr>
                                        <td class="ms-toolbar" nowrap="nowrap">
                                            <table>
                                                <tr>
                                                    <td class="ms-descriptiontext" nowrap="nowrap">
                                                        <SharePoint:CreatedModifiedInfo ControlMode="Edit" runat="server"/>
                                                    </td>
                                                    <td width="99%" class="ms-toolbar" nowrap="nowrap"><IMG SRC="/_layouts/15/images/blank.gif" width="1" height="18"/></td>
                                                    <td class="ms-toolbar" nowrap="nowrap">
                                                        <SharePoint:SaveButton runat="server" ControlMode="Edit" id="savebutton2"/>
                                                    </td>
                                                </tr>
                                            </table>
                                        </td>
                                    </tr>
                                </xsl:template>
                                <xsl:template name="dvt_1.rowedit">
                                    <xsl:param name="Pos" select="position()"/>
                                    <tr>
                                        <td>
                                            <xsl:if test="$dvt_1_automode = '1'" ddwrt:cf_ignore="1">
                                                    <span ddwrt:amkeyfield="ID" ddwrt:amkeyvalue="ddwrt:EscapeDelims(string(@ID))" ddwrt:ammode="view"></span>
                                            </xsl:if>                                
                                            <table cellpadding="4" cellspacing="0" border="0">
                                                <tr>        
                                                    <th class="ms-vh SmallHeader">Created</th>          
                                                    <th class="ms-vh SmallHeader">Quote</th>
                                                    <th class="ms-vh SmallHeader">RFQ Manager</th>
                                                    <th class="ms-vh SmallHeader">Assigned To</th>
                                                    <th class="ms-vh SmallHeader">Value</th>
                                                    <th class="ms-vh SmallHeader">Status</th>
                                                </tr>        
                                                  <tr valign="middle">                        
                                                      <td class="ms-vb2"><SharePoint:FormField runat="server" id="fff2{$Pos}" ControlMode="Display" FieldName="Created" __designer:bind="{ddwrt:DataBind('u',concat('fff2',$Pos),'Value','ValueChanged','ID',ddwrt:EscapeDelims(string(@ID)),'@Created')}"/></td>           
                                                      <td class="ms-vb2" id="QNContrainer"><SharePoint:FormField runat="server" id="fff10{$Pos}" ControlMode="Display" FieldName="Quote_x0020__x0023_" __designer:bind="{ddwrt:DataBind('u',concat('fff10',$Pos),'Value','ValueChanged','ID',ddwrt:EscapeDelims(string(@ID)),'@Quote_x0020__x0023_')}"/></td>
                                                      <td class="ms-vb-user"><SharePoint:FormField runat="server" id="fff5{$Pos}" ControlMode="Display" FieldName="Account_x0020_Manager" __designer:bind="{ddwrt:DataBind('u',concat('fff5',$Pos),'Value','ValueChanged','ID',ddwrt:EscapeDelims(string(@ID)),'@Account_x0020_Manager')}"/></td>
                                                      <td class="ms-vb-user"><SharePoint:FormField runat="server" id="fff7{$Pos}" ControlMode="Display" FieldName="Assigned_x0020_To" __designer:bind="{ddwrt:DataBind('u',concat('fff7',$Pos),'Value','ValueChanged','ID',ddwrt:EscapeDelims(string(@ID)),'@Assigned_x0020_To')}"/></td>
                                                      <td class="ms-vb2" style="color:#F15854;"><SharePoint:FormField runat="server" id="fff12{$Pos}" ControlMode="Display" FieldName="Quote_x0020_Value" __designer:bind="{ddwrt:DataBind('u',concat('fff12',$Pos),'Value','ValueChanged','ID',ddwrt:EscapeDelims(string(@ID)),'@Quote_x0020_Value')}"/></td>
                                                      <td class="ms-vb2"><SharePoint:FormField runat="server" id="fff14{$Pos}" ControlMode="Display" FieldName="Status" __designer:bind="{ddwrt:DataBind('u',concat('fff14',$Pos),'Value','ValueChanged','ID',ddwrt:EscapeDelims(string(@ID)),'@Status')}"/></td>
                                                  </tr>
                                                <tr>  
                                                    <td colspan="6">
                                                        <div id="Tabs">
                                                            <ul>
                                                                <li id="RFQTab">
                                                                <a href="#RFQ">
                                                                    <span>RFQ</span>
                                                                </a>
                                                                </li>
                                                            </ul>
                                                            <div id="RFQ">
                                                                <table border="0" cellspacing="0" cellpadding="4" width="100%">
                                                                    <tr>
                                                                        <td colspan="2" class="ms-formlabel">
                                                                            <H3 class="ms-standardheader">
                                                                            <nobr>
                                                                                Project Name<span class="ms-formvalidation"> *</span>
                                                                            </nobr>
                                                                            </H3>
                                                                        </td>
                                                                    </tr>
                                                                    <tr>
                                                                        <td colspan="2" class="ms-formbody longField">
                                                                            <span style="color:red;">{{<xsl:value-of select="@ID"/>}}</span>
                                                                            <SharePoint:FormField runat="server" id="ff1{$Pos}" ControlMode="Edit" FieldName="Title" __designer:bind="{ddwrt:DataBind('u',concat('ff1',$Pos),'Value','ValueChanged','ID',ddwrt:EscapeDelims(string(@ID)),'@Title')}"/>
                                                                            <SharePoint:FieldDescription runat="server" id="ff1description{$Pos}" FieldName="Title" ControlMode="Edit"/>
                                                                        </td>
                                                                    </tr>

这里删除了许多行具有相同语法的字段,以求清晰。

代码语言:javascript
复制
                                                                </table>
                                                            </div>
                                                        </div>
                                                    </td>
                                                </tr>  
                                            </table>
                                            <br/>
                                        </td>
                                    </tr>
                                </xsl:template>
                            </xsl:stylesheet>
                        </Xsl>
                        <DataFields>@Title,Project Name;@Product,Product;@Customer,Customer;@Account_x0020_Manager,Account Manager;@emailOptions,emailOptions;@Assigned_x0020_To,Assigned To;@Lead,Lead;@Quickship,Quickship;@Status,Status;@Notes,Notes;@ID,ID;@ContentType,Content Type;@Modified,Modified;@Created,Created;@Author,Created By;@Editor,Modified By;@_UIVersionString,Version;@Attachments,Attachments;@ItemChildCount,Item Child Count;@FolderChildCount,Folder Child Count;</DataFields>
                        <ParameterBindings>
                             <ParameterBinding Name="ListItemId" Location="QueryString(SPID)" DefaultValue="0"/>
                             <ParameterBinding Name="weburl" Location="None" DefaultValue="http://jam3iya4"/>
                             <ParameterBinding Name="ListID" Location="None" DefaultValue="{5A1F5F46-E308-440D-A7CE-3FF0587D9B4B}"/>
                             <ParameterBinding Name="dvt_apos" Location="Postback;Connection"/>
                             <ParameterBinding Name="ManualRefresh" Location="WPProperty[ManualRefresh]"/>
                             <ParameterBinding Name="UserID" Location="CAMLVariable" DefaultValue="CurrentUserName"/>
                             <ParameterBinding Name="Today" Location="CAMLVariable" DefaultValue="CurrentDate"/>
                        </ParameterBindings>
                    </WebPartPages:DataFormWebPart>
EN

回答 1

Stack Overflow用户

发布于 2015-12-28 08:15:38

好的,我设法解决了这个问题,希望这能帮助其他面临同样问题的人。事实证明(再次证明这只是实验性的,我希望有人比我更精明地证实这一点),在定制的webpart中使用DataFormWebPart是可行的。当我使用visual创建我的可视webpart时,它创建了第一个添加到webpart中的用户控件,并且根据习惯,我会将我的所有控件都放在其中,包括DataFormWebPart。这是好的插入表单,它的工作完美,保存数据,并继续重定向。在编辑表单中,它正确显示,但保存时触发的事件根本不保存,字段被重置。这个问题的解决方案是

  1. 在sharepoint设计器中为需要编辑的列表创建编辑表单。
  2. 然后在浏览器中导航到该表单并编辑该页面(在浏览器中)
  3. 用其中的表单编辑webpart并导出它。
  4. 现在,webpart文件只是一个包含DataFormWebPart所有属性列表的xml文件。可以在visual studio中导入此文件。
  5. 对xsl或绑定的任何自定义都可以在这个文件中完成(我使用xsllink路由并链接到我保存在站点资产中的外部xsl文件)。
  6. 虽然将此webpart包含到您的项目中,但不要将其添加到ascx文件中,只需将其以编程方式加载到webpart .cs中(作为您的用户控件(而不是子控件)的兄弟关系)
  7. 这是可选的,我创建了一个继承DataFormWebPart的类,并将它与这个but部件相关联,这样我就可以编程地操作一些属性,并在构造函数中传递一些初始化参数,但实际上.你没必要--我只是出于礼貌
  8. 此时,您的编辑表单是完全可用的,您可以从自定义的and部件中编辑和保存您的内容,如果您在将列表guid放置在参数等方面非常小心,则可以在不同的服务器上重用该and部件。

我花了一段时间,到目前为止,我还不知道为什么当DataFormWebPart在ascx里面的时候出现了一个无声的错误,但是嘿,我没有找回我生命中的这几天,所以不妨把它归结为体验和“乐趣”。

干杯:)

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34475216

复制
相关文章

相似问题

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