如何从文本区域输入文本

Ber*_*ice 1 javascript jquery tinymce

我试图在ASP.NET MVC 4 Web应用程序中与SignalR建立连接.我需要做的是让用户在文本区域写入,点击后我尝试将用户写的消息发送到同一页面上的所有客户端.

我陷入了一个非常简单的步骤.要阅读用户在textarea中写入的内容,我使用以下代码:

var msg = $('#editor').text();
alert(msg);
Run Code Online (Sandbox Code Playgroud)

我正在使用警报框进行测试.问题是警报框显示为空,即消息未正确读取.editor是html文件中我的文本区域的id.

这是所有的JavaScript文件:

$(function ()
    {
        var edit = $.connection.editorHub;

        edit.client.broadcastMessage = function (message) {

            var msg = $('#editor').text();
            alert(msg);

            // Add the message to the page. 
            $('#editor').append(msg);
        };

        $.connection.hub.start().done(function () {
            $('#button').click(function () {
               // call the send method in EditorHub
                chat.server.send($('#editor').val());
            });
        });
    });
Run Code Online (Sandbox Code Playgroud)

这是HTML文件:

@{
   ViewBag.Title = "- Editor";
   ViewBag.ContentStyle = "/Content/CSS/editor.css";
}

 <script src="/Scripts/jquery-1.6.4.min.js" ></script>
 <script src="/Scripts/jquery.signalR-1.0.0.js"></script>
 <script src="/signalr/hubs"></script>
 <script type="text/javascript" src="~/Content/tinyMCE/tiny_mce.js" ></script> 
 <script type="text/javascript" src="~/Scripts/EditorHandler.js"></script>

 <button id="button">Click me</button>

 <form>  
       <textarea id="editor" name="content" cols="100" rows="30">
   </textarea>
 </form>
Run Code Online (Sandbox Code Playgroud)

它是通过ajax加载的,因此这是内容..其余部分在Master文件中

ade*_*neo 7

您需要从textarea获取值,而不是text():

$('#editor').val();
Run Code Online (Sandbox Code Playgroud)

或者从TinyMCE获取内容:

var msg = tinyMCE.get('#editor').getContent()
Run Code Online (Sandbox Code Playgroud)

要么

var msg = tinyMCE.activeEditor.getContent();
Run Code Online (Sandbox Code Playgroud)

  • @adeneo很可能tinyMCE隐藏了编辑器并用它自己替换它,你需要告诉tinyMCE将内容从tinyMCE编辑器推送到隐藏的textarea. (2认同)