zoukankan      html  css  js  c++  java
  • 使用sharepoint自带的文本编辑器2

    首先贴出参考文章链接

    http://kb.cnblogs.com/a/1222221/

    抛砖引玉:关于 SharePoint 内容编辑器中的文件上传

    先照抄第一篇链接的一些东西吧…

    sharepoint里面自带的编辑器2种样式.第一个为:FullHtml , 第二个为:Compatible

    image image

    直接调用Sharepoint控件: SharePoint中的富文本编辑器控件

    <%@ Register Tagprefix="SharePoint" Namespace="Microsoft.SharePoint.WebControls" Assembly="Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>

    <SharePoint:InputFormTextBox Title="" class="ms-input" Width="800px" ID="txtTestRecord" Runat="server" TextMode="MultiLine"  Rows="15" RichText="true" AllowHyperlink="true" RichTextMode="FullHtml" />

     

    <%@ Register Tagprefix="SharePointPublish" Namespace="Microsoft.SharePoint.Publishing.WebControls" Assembly="Microsoft.SharePoint.Publishing, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>

    <SharePointPublish:HtmlEditor Width="800px" ID="txtTestRecord" Runat="server" id="editor1" />

     

    <%@ Page Language="C#" %>
    <%@ Assembly Name="Microsoft.Office.Server, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
    <%@ Import Namespace="Microsoft.SharePoint" %>
    
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    
    <script runat="server">
        protected void Page_Load(object sender, EventArgs e)
        {         }
    </script>
    
    <%--引用sharepoint里面的JS文件 当初没有init.js报browseris 未定义的错误,把init.js引用后问题解决--%>
    <script type="text/javascript" language="javascript" src="/_layouts/1033/INIT.js"></script>
    <script type="text/javascript" language="javascript" src="/_layouts/1033/form.js"></script>
    
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head id="Head1" runat="server">
        <title></title>
    </head>
    <body>
        <form id="form1" runat="server">
        
        <div>
            <!--这里写的行内样式好像没有效果-->
            <textarea name="txtTextArea1" rows="6" cols="60" id="txtTextArea1" title="Please Input"
                style="border: 1px solid blue"></textarea>
                <p></p>
            <asp:TextBox ID="TextBox1" runat="server" style="width:300px;"></asp:TextBox>
    
            <script language="javascript" type="text/javascript">
                RTE_ConvertTextAreaToRichEdit("txtTextArea1", false, false, "", "1033", null, null, null, null, null, "Compatible", "\u002f", null, null, null, null);
                //如果使用服务器控件,则需要用<%=TextBox1.ClientID%>, 1033:为美国,2052为中国 可以看你的安装目录 ,[Compatible,FullHtml]
                RTE_ConvertTextAreaToRichEdit("<%=TextBox1.ClientID%>", true, false, "", "1033", null, null, null, null, null, "FullHtml", "\u002f", null, null, null, null);      
            </script>
        </div>
        </form>
    </body>
    </html>
    

    txtTextArea1的效果图: RTE_ConvertTextAreaToRichEdit("txtTextArea1"falsefalse"""1033"nullnullnullnull,null"Compatible""\u002f"nullnullnullnull);

    1

    TextBox1的效果图:RTE_ConvertTextAreaToRichEdit("<%=TextBox1.ClientID%>"truefalse"""1033"nullnullnull,nullnull"FullHtml""\u002f"nullnullnullnull);

    2

     

    注意对比他的参数, 第二个参数和 后面的 [Compatible,FullHtml] , 当第二个参数为false ,他的上传图片功能就可以使用Browse的方式了! 不过上面的文章提到过不能保存,这个我还没有测试的!

    上面的东西样式不是很好看! 写行内样式没有效果,我想应该在其他参数里面可以设置,看RTE_ConvertTextAreaToRichEdit函数可以知道, 待研究…  [如果你知道,请告诉我,谢谢]

     

    如何调整SharePoint InputformTextbox的宽度

    var name = "<%= ReportTextBox.ClientID %>";

    (document.getElementById(name + "_toolbar")).style.width = "100%";

    (document.getElementById(name + "_iframe")).style.width = "100%";

     

     

    附:RTE_ConvertTextAreaToRichEdit方法源码 【可以在C:\Program Files\Common Files\microsoft shared\Web Server Extensions\12\TEMPLATE\LAYOUTS\1033\FORM.js】

    注意如果你安装的sharepoint为中文,请把 1033 改为 2052

    function RTE_ConvertTextAreaToRichEdit(
                strBaseElementID,
                fRestrictedMode,
                fAllowHyperlink,
                strDirection,
                strWebLocale,
                fSimpleTextOnly,
                fEditable,
                fUseDynamicHeightSizing,
                iMaxHeightSize,
                iMinHeightSize,
                strMode,
                urlWebRoot,
                strThemeUrl,
                strBodyClassName,
                fAllowRelativeLinks,
                strBaseUrl,
                fUseDynamicWidthSizing,
                iMaxWidthSize,
                iMinWidthSize,
                fEnforceAccessibilityMode,
                fPreserveScript,
                fHookUpEvents,
                fGenerateToolbar
                ) {
            ;
            if (!(browseris.ie5up && browseris.win32)) {
                return;
            }
            fEnforceAccessibilityMode = (fEnforceAccessibilityMode == null || fEnforceAccessibilityMode);
            if (IsAccessibilityFeatureEnabled() && fEnforceAccessibilityMode) {
                return;
            }
            fSimpleTextOnly = (fSimpleTextOnly != null && fSimpleTextOnly);
            fRestrictedMode = (fSimpleTextOnly) ? true : fRestrictedMode;
            fEditable = (null == fEditable) ? true : fEditable;
            fUseDynamicHeightSizing = (fUseDynamicHeightSizing != null && fUseDynamicHeightSizing);
            iMaxHeightSize = (null == iMaxHeightSize || iMaxHeightSize <= 0) ?
            g_iDefaultMaxHeightSize : iMaxHeightSize;
            iMinHeightSize = (null == iMinHeightSize || iMinHeightSize <= 0 || iMinHeightSize > iMaxHeightSize) ?
            g_iDefaultMinHeightSize : iMinHeightSize;
            fUseDynamicWidthSizing = (fUseDynamicWidthSizing != null && fUseDynamicWidthSizing);
            iMaxWidthSize = (null == iMaxWidthSize || iMaxWidthSize <= 0) ?
            g_iDefaultMaxWidthSize : iMaxWidthSize;
            iMinWidthSize = (null == iMinWidthSize || iMinWidthSize <= 0 || iMinWidthSize > iMaxWidthSize) ?
            g_iDefaultMinWidthSize : iMinWidthSize;
            fHookUpEvents = (null == fHookUpEvents || fHookUpEvents);
            fGenerateToolbar = (null == fGenerateToolbar || fGenerateToolbar);
            if (strMode != "FullHtml")
                strMode = "Compatible";
            if (null == strBodyClassName) {
                strBodyClassName = "ms-formbody";
            }
            aSettings = new Array();
            RTE_InitializeExtendedRichTextSupport(strBaseElementID);
            var variables = RTE_GetEditorInstanceVariables(strBaseElementID);
            var fFullHtml = false;
            if (strMode == "FullHtml") {
                fFullHtml = true;
                fAllowHyperlink = false;
                variables.overrides.GetToolBarDefinition = RTE_FullHtmlToolBarDefinitionFactory(
                    fEnforceAccessibilityMode);
                aSettings.fRestrictedMode = true;
                aSettings.fAllowHyperlink = false;
                aSettings.fIsVisible = true;
            }
            else {
                aSettings.fRestrictedMode = fRestrictedMode;
                aSettings.fAllowHyperlink = fAllowHyperlink;
                aSettings.fIsVisible = !fSimpleTextOnly;
            }
            aSettings.urlWebRoot = (urlWebRoot == null || urlWebRoot == "/") ?
            "" : urlWebRoot;
            aSettings.fAllowRelativeLinks = (fAllowRelativeLinks == null) ? false : fAllowRelativeLinks;
            aSettings.fPreserveScript = (fPreserveScript == null) ? false : fPreserveScript;
            variables.aSettings = aSettings;
            var elemTextArea = RTE_GetEditorTextArea(strBaseElementID);
            var strHtmlToEdit = elemTextArea.innerText;
            if ((null == strHtmlToEdit) || (0 == strHtmlToEdit.length)) {
                strHtmlToEdit = "<div></div>";
            }
            g_elemRTELastTextAreaConverted = elemTextArea;
            window.attachEvent("onload",
            new Function(
                "RTE_TextAreaWindow_OnLoad('" + strBaseElementID + "');"));
            var aHtmlToAppend = new Array();
            if (fGenerateToolbar) {
                aHtmlToAppend.push(RTE_GenerateToolBarHtmlFromSettings(
                strBaseElementID, strWebLocale, elemTextArea, aSettings));
            }
            aHtmlToAppend.push(RTE_GenerateIFrameEditorHtml(
            strBaseElementID, elemTextArea, fRestrictedMode, fAllowHyperlink));
            var strHtmlToAppend = aHtmlToAppend.join("");
            elemTextArea.insertAdjacentHTML("afterEnd", strHtmlToAppend);
            if (fHookUpEvents) {
                elemTextArea.onfocus = new Function("RTE_TextArea_OnFocus('" + strBaseElementID + "')");
                elemTextArea.style.display = "none";
                variables.onBeforeUnloadFunc = new Function(
                    "RTE_TransferIFrameContentsToTextArea('" + strBaseElementID + "');");
                window.attachEvent("onbeforeunload", variables.onBeforeUnloadFunc);
                var findForm = elemTextArea;
                while (findForm.tagName != "FORM" && findForm.tagName != "WINDOW") {
                    findForm = findForm.parentElement;
                }
                findForm.attachEvent("onsubmit",
                new Function(
                    "RTE_TransferIFrameContentsToTextArea('" + strBaseElementID + "');"));
            }
            var aEditorHtml = new Array();
            aEditorHtml.push("<html><head>");
            if (null != strBaseUrl && true == fAllowRelativeLinks) {
                aEditorHtml.push("<base href=\"");
                aEditorHtml.push(strBaseUrl);
                aEditorHtml.push("\"/>");
            }
            aEditorHtml.push("<link rel=\"stylesheet\" type=\"text/css\" href=\"");
            aEditorHtml.push(RTE_GetServerRelativeStylesheetUrl("core.css", strWebLocale));
            aEditorHtml.push("\">");
            if (null != strThemeUrl) {
                aEditorHtml.push("<link rel=\"stylesheet\" type=\"text/css\" href=\"");
                aEditorHtml.push(strThemeUrl);
                aEditorHtml.push("\">");
            }
            aEditorHtml.push("</head><body class=\"");
            aEditorHtml.push(strBodyClassName);
            aEditorHtml.push("\" style=\"background-color: white;border:none;\"></body></html>");
            var strEditorHtml = aEditorHtml.join("");
            var docEditor = RTE_GetEditorDocument(strBaseElementID);
            docEditor.designMode = (fEditable ? "on" : "off");
            docEditor = RTE_GetEditorDocument(strBaseElementID);
            docEditor.open("text/html", "replace");
            docEditor.write(strEditorHtml);
            docEditor.close();
            docEditor.body.scroll = "yes";
            docEditor.body.wordWrap = false;
            docEditor.body.contentEditable = true;
            docEditor.body.innerHTML = strEditorHtml;
            if (fHookUpEvents) {
                RTE_EventHookUp(strBaseElementID);
            }
            if (fRestrictedMode) {
                docEditor.body.ondragenter = new Function("RTE_OnDragEnter(this);");
                docEditor.body.ondragover = new Function("RTE_OnDragOver(this);");
                docEditor.body.ondragdrop = new Function("RTE_OnDrop(this);");
            }
            if (strDirection != "" &&
            strDirection != "None") {
                docEditor.dir = strDirection;
            }
            else {
                docEditor.dir = document.dir;
            }
            if (fRestrictedMode && !fFullHtml) {
                docEditor.body.setAttribute(
                g_strRTERestrictedModeAttributeName, "true");
                docEditor.body.onpaste = new Function("RTE_OnPaste_Restricted('" + strBaseElementID + "', this);");
            }
            if (fSimpleTextOnly) {
                docEditor.body.setAttribute(
                g_strRTESimpleTextOnlyAttributeName, "true");
            }
            if (fUseDynamicHeightSizing || fUseDynamicWidthSizing) {
                var strFuncCall = "";
                if (fUseDynamicHeightSizing) {
                    docEditor.body.style.wordWrap = "break-word";
                    docEditor.body.setAttribute(g_strRTEUseDynamicHeightSizing, "true");
                    docEditor.body.setAttribute(
                    g_strRTEMinHeightSizeAttributeName, iMinHeightSize);
                    docEditor.body.setAttribute(
                    g_strRTEMaxHeightSizeAttributeName, iMaxHeightSize);
                    strFuncCall = "RTE_DocEditor_AdjustHeight('" + strBaseElementID + "');";
                }
                if (fUseDynamicWidthSizing) {
                    docEditor.body.style.wordWrap = "normal";
                    docEditor.body.setAttribute(g_strRTEUseDynamicWidthSizing, "true");
                    docEditor.body.setAttribute(
                    g_strRTEMaxWidthSizeAttributeName, iMaxHeightSize);
                    docEditor.body.setAttribute(
                    g_strRTEMinWidthSizeAttributeName, iMinHeightSize);
                    strFuncCall += "RTE_DocEditor_AdjustWidth('" + strBaseElementID + "');";
                }
                var ifmEditor = RTE_GetEditorIFrame(strBaseElementID);
                docEditor.attachEvent(
                "onkeydown",
                new Function(
                strFuncCall));
                ifmEditor.attachEvent(
                "onscroll",
                new Function(
                strFuncCall));
                window.attachEvent(
                 "onload",
                 new Function(
                strFuncCall));
                if (fHookUpEvents) {
                    if (fUseDynamicHeightSizing) {
                        RTE_DocEditor_AdjustHeight(strBaseElementID);
                    }
                    if (fUseDynamicWidthSizing) {
                        RTE_DocEditor_AdjustWidth(strBaseElementID);
                    }
                }
            }
            if (fAllowHyperlink) {
                docEditor.body.setAttribute(
                g_strRTEAllowHyperlinkAttributeName, "true");
            }
            docEditor.body.setAttribute(
            g_strRTEBaseElementIDAttributeName, strBaseElementID);
            docEditor.body.setAttribute(
            g_strRTEWebLocaleAttributeName, strWebLocale);
            g_rgstrRTEAllEditorsInThePage[g_rgstrRTEAllEditorsInThePage.length] = strBaseElementID;
            if (fGenerateToolbar) {
                RTE_DisableToolBar(strBaseElementID);
                var ifmEditorObj = RTE_GetEditorElement(strBaseElementID);
                ifmEditorObj.tabIndex = elemTextArea.tabIndex;
                RTE_ToolBarMnemonicInitialization(strBaseElementID);
            }
        }
     
    另: sharepoint mysite 的edit profile的编辑页面 用的控件, 我试图把Portal.css也引用到我的页面上,但是编辑器依然没有效果!

    <Sharepoint:CssRegistration name="portal.css" runat="server"/>
        <img src="/_layouts/images/trans.gif" height="8" width="1" alt=""><br clear="all">
        <SPSWC:ProfilePropertyLoader runat="server" />
        <table width="1px" cellpadding=0 cellspacing=0>
           <tr><td width="100%"><SPSWC:ProfileEditor id="ProfileEditor" runat="server" /></td><td width="20">&nbsp;</td></tr>
        </table>
        <Sharepoint:FormDigest runat="server" id="FormDigest" />

  • 相关阅读:
    css3 容器内容垂直居中
    css3 背景图动画一
    C# linq 最大、最小对象的扩展
    线程中为控件赋值Winform
    C#在高分屏上让窗体程序忽略系统的显示缩放
    获取搜索到的内容
    XMLHelper
    获得WebBrowser中的图片数据
    单例模式通用类
    将实体类、匿名对象转换为SqlParameter列表
  • 原文地址:https://www.cnblogs.com/Areas/p/2196465.html
Copyright © 2011-2022 走看看