1

我已经使用带有 ajaxtoolkit HtmlEditorExtender(Rich textbox) 的文本框使用谷歌翻译 Javascript 将英语翻译成古吉拉特语。它仅适用于文本框,但当我使用 HtmlEditorExtender(Rich textbox) 时它不起作用。

下面是我使用的 Javascript。

<script type="text/javascript" src="https://www.google.com/jsapi"></script>
    <script type="text/javascript">
        google.load("elements", "1", {
            packages: "transliteration"
        });
        function onLoad() {
            var options = {
                sourceLanguage:
                google.elements.transliteration.LanguageCode.ENGLISH,
                destinationLanguage:
                google.elements.transliteration.LanguageCode.GUJARATI,

                shortcutKey: 'ctrl+g',
                transliterationEnabled: true
            };
            var control =
            new google.elements.transliteration.TransliterationControl(options);
            control.makeTransliteratable(['<%=TextBox1.ClientID%>']);
        }
        google.setOnLoadCallback(onLoad);

        var finalString = "";
        function Changed(textControl) {

            var _txtUnicodeName = document.getElementById('<%=TextBox1.ClientID%>');

            var _EnteredString = _txtUnicodeName.value;
        }
    </script>

    <asp:UpdatePanel ID="Activistupdatepanel" runat="server">
                    <ContentTemplate>
                        <div>
                            <asp:Button ID="Button1" runat="server" Text="Button" onclick="Button1_Click" />
                            <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
                    <ajaxtoolkit:HtmlEditorExtender ID="htmlEditorExtender1" TargetControlID="TextBox1"
                        runat="server" EnableSanitization="False" Enabled="True">
                    </ajaxtoolkit:HtmlEditorExtender>
                        </div>
                    </ContentTemplate>
                </asp:UpdatePanel>
4

1 回答 1

0

它不起作用,因为您不应该使用隐藏的 TextBox。相反,您应该使用HtmlEditorExtender's editor div。试试这个:

        function onLoad() {
        document.getElementById('<%=htmlEditorExtender1.ClientID%>_ExtenderContentEditable').setAttribute("contentEditable", "true"); //*** added this
        var options = {
            sourceLanguage:
            google.elements.transliteration.LanguageCode.ENGLISH,
            destinationLanguage:
            google.elements.transliteration.LanguageCode.GUJARATI,

            shortcutKey: 'ctrl+g',
            transliterationEnabled: true
        };
        var control =
        new google.elements.transliteration.TransliterationControl(options);
        control.makeTransliteratable(['<%=htmlEditorExtender1.ClientID%>_ExtenderContentEditable']); //**** changed this
    }
    google.setOnLoadCallback(onLoad);

基本上,我只是将 TextBox 更改为HtmlEditorExtender的编辑器 div,即<%=htmlEditorExtender1.ClientID%>_ExtenderContentEditable

根据官方文档使用 div 你需要contentEditable=true属性。下面的第一行onLoad()将该自定义属性添加到 div。

.makeTransliteratable(elementIds, opt_options) 在提供的 HTML 元素上启用音译。此方法的参数是:

elementIds 是一个数组,其中包含您希望启用音译的可编辑元素 ID 或元素引用字符串。可编辑元素可以是:
一个文本字段
一个文本区域
** contentEditable="true" 的 div **
带有 designMode="on" 的 iframe
具有 contentEditable="true" 正文的 iFrame。确保在启用音译之前加载 iFrame。

这对我有用。如果您在完成这项工作时遇到困难,请告诉我。

于 2012-12-31T16:48:01.303 回答