欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery實現(xiàn)簡單聊天室

 更新時間:2020年02月08日 17:57:43   作者:BinkiCyo  
這篇文章主要為大家詳細(xì)介紹了jQuery實現(xiàn)簡單聊天室,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

自從看了jQuery后,頓時感覺其的確很簡單易學(xué)。下面就一把自己寫的一個簡易的聊天室程序?qū)懗鰜怼?/p>

主要就是利用jQuery的ajax,然后,別的其實也沒什么了。先上client端的程序吧。

<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8"/>
 <meta name="viewport" content="width=device-width"/>
 <link rel="stylesheet" type="text/css" href="./styles/chat-mobile.css" rel="external nofollow" />
 <script type="text/javascript" src="./scripts/jquery-1.8.2.min.js"></script>
 <script type="text/javascript">
 $(function() {
 timestamp = 0;
 updateMsg(timestamp);
 $('button').click(function() { //重點是這里,從這里向服務(wù)器端發(fā)送數(shù)據(jù)
  $.post('chat.php', {
  'message': $('#msg').val(),
  'name': $('#name').val(),
  'timestamp': timestamp
  },function(xml) {
  $('#msg').val('');
  addMessage(xml);
  });
  return false;
 });
 
 $('#name').blur(function (){ //僅僅用來控制名字輸入框的背景
  if ($('#name').val()) {
  $(this).css({"background": "url(images/background.jpg)", "border": "2px dashed #fff"});
  };
 });
 $('#name').click(function () {
  $(this).css({"background": "#fff", "border": "2px solid #fff"});
 })
 
 });
 //update message
 function updateMsg(timestamp) { //從服務(wù)器端更新聊天數(shù)據(jù),并載入吧
 $.post('chat.php', {'timestamp': timestamp}, function(xml) {
  $('#loading').remove();
  addMessage(xml);
 });
 setTimeout('updateMsg(timestamp);', 1000); //1s刷新一次信息
 }
 function addMessage(xml) { //解析xml,并添加到頁面內(nèi)
 if($('status', xml).text() == 2) {
  return;
 };
 timestamp = $('timestamp', xml).text();
 $('message', xml).each(function() {
  var author = $('author', this).text();
  var content = $('content', this).text();
  var time = $('time', this).text();
  var htmlcode = '<div><strong>' + author + ': </strong><label>' + time + '</label><p>' + content + '</p></div>';
  $('#messageWindow').append(htmlcode);
  scrollToBottom();
 });
 }
 function scrollToBottom () { //控制滾動條一直顯示在底部
 var height = document.getElementById('messageWindow').scrollHeight;
 if (height > $('#messageWindow').scrollTop()) {
  $('#messageWindow').scrollTop(height);
 }
 }
 
 </script>
</head>
<body>
 <header>
 <div id="hr"></div>
 </header>
 
 <div id="wrapper">
 <div id="window">
  <div id="messageWindow">
  <span id="loading">loading...</span>
  </div>
  <form id="chatform">
  <label>your message:</label>
  <textarea type="text" id="msg" size="50"/></textarea>
  <input type="text" id="name" size="10" placeholder="your name"/>
  <button accesskey="s">Send</button>
  </form>
 </div>
 </div>
 <br/>
 <br/>
 <p id="hint">Hint: 移動版的,開放的聊天室</p>
 
 <footer>
 <p>©SamuraiMe</p>
 </footer>
</body>
</html>

服務(wù)器端我是用php寫的簡單程序,把產(chǎn)生的xml貼出來。其實就是簡簡單單給數(shù)據(jù)庫存數(shù)據(jù)取數(shù)據(jù)的一個過程。

<?xml version="1.0" encoding="utf-8"?>
<response>
 <status></status>
 <timestamp></timestamp>
 <message>
 <author></author>
 <content></content>
 <time></time>
 </message>
</response>

上面就是最后成品,手機(jī)截圖不方便,就在firefox上截了,效果是一樣的。雖然css寫得磕磣了點。但是還是有需要注意的地方。就像圖上'how are you ...'那一大串,如果換成'1111...111'一大串,就會產(chǎn)生scroll-x,移動端好像沒有出現(xiàn)滾動條,消息就看不到了。這怎么能容忍。于是要加

word-wrap: break-word;

本來我以為要寫字符串程序,自己手動來換行,有了word-wrap就一句話搞定了。

最后要說,jQuery的確是簡單好用,但終究是一個輕量級庫,很多事情是完成不了的,就比如讓那個滾動條一直顯示在底部,我就發(fā)現(xiàn)無法用jQuery完成,也許是我才看jQuery,還沒找到獲取scrollHeight的方法,最后只能回到不熟悉的js上面去。

var height = document.getElementById('messageWindow').scrollHeight;
if (height > $('#messageWindow').scrollTop()) {
	$('#messageWindow').scrollTop(height);
}

差點忘了說了。

<meta name="viewport" content="width=device-width"/>

在移動端有一個虛擬可視區(qū)域,比實際的可視區(qū)域要大一些。第一次在手機(jī)上查看的時候,總有scroll出現(xiàn),用了這個meta就可以解決了。

最后,這是我第一篇技術(shù)博客。希望對看到的人能有所幫助。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 基于jQuery替換table中的內(nèi)容并顯示進(jìn)度條的代碼

    基于jQuery替換table中的內(nèi)容并顯示進(jìn)度條的代碼

    這個例子使我更加明白呈現(xiàn)數(shù)據(jù)是前端工作滴一部分,如何使table中的數(shù)值變?yōu)榍逦貤l狀圖呢?聽我細(xì)細(xì)道來
    2011-08-08
  • js過濾HTML標(biāo)簽以及空格的思路及代碼

    js過濾HTML標(biāo)簽以及空格的思路及代碼

    今天要做一個應(yīng)用--判斷編輯器中文字的個數(shù)。如果少如20個字就不能讓其提交。沒多想,正好周末的時候看了一下js中正則表達(dá)式的內(nèi)容。很容易就想到了要用正則表達(dá)式來解決這個問題。雖說看了正則表達(dá)式的內(nèi)容是看了,但是畢竟還是剛接接觸,連基本的概念都很模糊,于是只好在網(wǎng)上找到如下的代碼:
    2013-05-05
  • jQuery針對各類元素操作基礎(chǔ)教程

    jQuery針對各類元素操作基礎(chǔ)教程

    這篇文章主要介紹了jQuery針對各類元素操作基礎(chǔ),包括jQuery基礎(chǔ)操作、選擇要操作的元素及處理DOM元素等,是深入學(xué)習(xí)jQuery所必備的基礎(chǔ)技能,需要的朋友可以參考下
    2014-08-08
  • 多個jQuery版本共存的處理方案

    多個jQuery版本共存的處理方案

    本文給大家分享的是一個經(jīng)常需要碰到的問題的解決方案,如何才能讓一個頁面中同時存在多個jQuery呢,這就是今天我們需要探討的話題了。
    2015-03-03
  • 一個簡單的jquery的多選下拉框(自寫)

    一個簡單的jquery的多選下拉框(自寫)

    想在網(wǎng)上找一個插件用用,可是,網(wǎng)上的插件看起來都比較雜亂,我參考了網(wǎng)上的一些插件,自己用jquery寫了一個多選下拉框
    2014-05-05
  • JavaScript jQuery 中定義數(shù)組與操作及jquery數(shù)組操作

    JavaScript jQuery 中定義數(shù)組與操作及jquery數(shù)組操作

    這篇文章主要介紹了JavaScript jQuery 中定義數(shù)組與操作及jquery數(shù)組操作的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • 基于jQuery的圖片大小自動適應(yīng)實現(xiàn)代碼

    基于jQuery的圖片大小自動適應(yīng)實現(xiàn)代碼

    這個和以前弄的圖片遠(yuǎn)處放大有許多相同的地方,比如圖片預(yù)加載、有限容器顯示無限大圖片。
    2010-11-11
  • jQuery使用$.extend(true,object1, object2);實現(xiàn)深拷貝對象的方法分析

    jQuery使用$.extend(true,object1, object2);實現(xiàn)深拷貝對象的方法分析

    這篇文章主要介紹了jQuery使用$.extend(true,object1, object2);實現(xiàn)深拷貝對象的方法,結(jié)合實例形式分析了jQuery中$.extend(true,object1, object2);進(jìn)行深拷貝操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2019-03-03
  • jquery $.each()使用探討

    jquery $.each()使用探討

    想必大家對jquery $.each()并不陌生吧,使用它可以進(jìn)行元素的遍歷,下面有個不錯的示例,感興趣的朋友可以參考下
    2013-09-09
  • Validform+layer實現(xiàn)漂亮的表單驗證特效

    Validform+layer實現(xiàn)漂亮的表單驗證特效

    創(chuàng)建一個JavaScript表單驗證插件,可以說是一個繁瑣的過程,涉及到初期設(shè)計、開發(fā)與測試等等環(huán)節(jié)。實際上一個優(yōu)秀的程序員不僅是技術(shù)高手,也應(yīng)該是善假于外物的。本文就給大家結(jié)合2款優(yōu)秀的插件來實現(xiàn)這個問題,有需要的小伙伴可以參考下
    2016-01-01

最新評論