繁体   English   中英

尝试使用鼠标单击事件响应对jQuery HTML5聊天框程序进行编码

[英]Trying to code jQuery HTML5 chat box program with mouse click event response

我在为学校项目编码聊天框程序时遇到问题。 我的程序有3个问题。 首先,我的聊天消息未正确张贴在我的聊天框中。 其次,我希望能够单击退出并将其靠近窗口,但不确定如何操作。 最后,我希望聊天至少能够回显该消息或进行硬编码响应。 我正在研究如何做到这一点,我不太确定如何做到这一点。 我有一个样式表和html。 这是我的html:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <script src=http://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js ></script>
<link rel="stylesheet" type="text/css" href="jQuery.css">



//my issues seem to be in my Javascript between here************************************



<script type="text/javascript">
    $(document).ready(function(){
        $('#submitmsg').click(function(){
            var message = $('#usermsg').val()
            var old = $('#chatbox').html()

            $('#chatbox').html(old + '<p>' + message + '</p>');
        });
    });
</script>
<script >
    function close_window(url){
        var newWindow = window.open('', '_self', ''); //open the current window
        window.close(url);
    };
</script>


//and here*****************************************************************************
</head>
<body>
<div id="wrapper">
    <div id="menu">
        <p class="welcome">Welcome <b></b></p>

//Possible issue here*******************************************************************
        <p class="logout"><a id="exit" href="#" onclick="window.close();">Exit Chat</a></p>
        <div style="clear:both"></div>
    </div>

    <div id="chatbox">
        <p>Here's our chat data</p>
    </div>

    <form name="message" action="">
        <input name="usermsg" type="text" id="usermsg" size="63" />
        <input name="submitmsg" type="submit"  id="submitmsg" value="Send" />
    </form>
</div>      
</body>
</html>  

这是我的CSS:

body {
font:12px arial;
color: #222;
text-align:center;
padding:35px; }

form, p, span {
    margin:0;
    padding:0; }

input { 
    font:12px arial; }

a {
    color:#0000FF;
    text-decoration:none; }

a:hover { 
    text-decoration:underline; }

#wrapper, #loginform {
    margin:0 auto;
    padding-bottom:25px;
    background:#EBF4FB;
    width:75%;
    border:1px solid #ACD8F0; }

#loginform { 
    padding-top:18px; }

#loginform p { 
    margin: 5px; }

#chatbox {
    text-align:left;
    margin:0 auto;
    margin-bottom:25px;
    padding:10px;
    background:#fff;
    height:270px;
    width:430px;
    border:1px solid #ACD8F0;
    overflow:auto; }

#chatbox p {
    padding:1em;
    margin:1em;
    background:#E6E6E6;
    border:1px solid #BDBDBD;
    -moz-border-radius:4px;
}

#usermsg {
    width:395px;
    border:1px solid #ACD8F0; }

#submit { 
    width: 60px; }


.welcome { 
    float:left; }

.logout { 
    float:right; }

.msgln { 
    margin:0 0 2px 0; }

我很确定有些CSS是不必要的,但是当我尝试取出一些CSS时会引起问题。 任何帮助是极大的赞赏。

一个问题是您使用的表单随后会发布到同一页面-重新加载它。 我将您的代码复制到了一个测试页(称为chatTest.html)中,并点击了send按钮后得到了以下网址:

chatTest.html?usermsg=test+message&submitmsg=Send

您的消息确实会发布到聊天部分,但在页面重新加载时会被删除。 并且由于您未指定方法-它会将其视为获取表单,并将消息作为附加到url的querystring发布。

如果您打算将注释保存到数据库,则应将表单的操作更改为其他php页面,处理结果并将保存的内容返回到聊天部分-也许使用Ajax,这样您就不必在每次聊天提交时重新加载页面。

尝试复制以下内容-我将样式放到头部,将javascript移至末尾,然后将输入替换为按钮。 这与onclick关联,并将新评论添加到聊天窗口中。 它可以工作,但是可以做得更好,而且我还没有解决关闭窗口的问题,但这确实将新评论发布到了聊天区域。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <script src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js" ></script>
<style>
body {
font:12px arial;
color: #222;
text-align:center;
padding:35px; }

form, p, span {
    margin:0;
    padding:0; }

input { 
    font:12px arial; }

a {
    color:#0000FF;
    text-decoration:none; }

a:hover { 
    text-decoration:underline; }

#wrapper, #loginform {
    margin:0 auto;
    padding-bottom:25px;
    background:#EBF4FB;
    width:75%;
    border:1px solid #ACD8F0; }

#loginform { 
    padding-top:18px; }

#loginform p { 
    margin: 5px; }

#chatbox {
    text-align:left;
    margin:0 auto;
    margin-bottom:25px;
    padding:10px;
    background:#fff;
    height:270px;
    width:430px;
    border:1px solid #ACD8F0;
    overflow:auto; }

#chatbox p {
    padding:1em;
    margin:1em;
    background:#E6E6E6;
    border:1px solid #BDBDBD;
    -moz-border-radius:4px;
}

#usermsg {
    width:395px;
    border:1px solid #ACD8F0; }

#submit { 
    width: 60px; }


.welcome { 
    float:left; }

.logout { 
    float:right; }

.msgln { 
    margin:0 0 2px 0; }
    </style>
</head>
<body>
<div id="wrapper">
    <div id="menu">
        <p class="welcome">Welcome</p>
        <p class="logout"><a id="exit" href="#" onclick="window.close();">Exit Chat</a></p>
        <div style="clear:both"></div>
    </div>

    <div id="chatbox">
        <p>Here's our chat data</p>
    </div>

    <form name="message">
        <input name="usermsg" type="text" id="usermsg" size="63" />
        <button type="button" id="submitmsg" value="send">Send</button>    
    </form>
</div> 

<script>
    $(document).ready(function(){
        $('#submitmsg').click(function(){
            var message = $('#usermsg').val();
            $('#chatbox').append('<p>' + message + '</p>');
            $('#usermsg').val('');
        });
    });

 function close_window(url){
        var newWindow = window.open('', '_self', ''); //open the current window
        window.close(url);
    };
</script>

</body>
</html> 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM