在线客服系统

Original 2019-05-17 17:54:13 235
abstract:<!DOCTYPE html><html><head><meta charset="UTF-8"><title>DOM实战:模拟智能在线客服系统</title><style type="text/css">div:nth-child(1) {width: 450px;heig

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>DOM实战:模拟智能在线客服系统</title>

<style type="text/css">

div:nth-child(1) {

width: 450px;

height: 650px;

background-color: lightskyblue;

margin: 30px auto;

color: #333;

box-shadow: 2px 2px 2px #808080

}


h2 {

text-align: center;

margin-bottom: -10px;

}

div:nth-child(2) {

width: 400px;

height: 500px;

border: 4px double green;

background-color: #efefef;

margin: 20px auto 10px;

}


ul {

list-style: none;

line-height: 2em;

/*border: 1px solid red;*/

overflow: hidden;

padding: 15px;

}


table {

width: 90%;

height:80px;

margin: auto;

}


textarea{

/*width: 300px;*/

border: none;

resize: none;

background-color: lightyellow;


}

button {

width: 60px;

height: 40px;

background-color: seagreen;

color: white;

border: none;

/*text-align: left;*/


}

button:hover {

cursor: pointer;

background-color: orange;

}

</style>

</head>

<body>

<div>

<h2>在线客服</h2>

<div contenteditable="true">

<ul>

<li></li>

</ul>

</div>

<table>

<tr>

<td><textarea cols="50" rows="4" name="text"></textarea></td>

<td><button type=button>发送</button></td>

</tr>

</table>

</div>

<script type="text/javascript">

//获取到页面中的按钮,文本域,对话内容区

let btn = document.getElementsByTagName('button')[0];

let text = document.getElementsByName('text')[0];

let list = document.getElementsByTagName('ul')[0];

let sum = 0;


//添加按钮点击事件,获取用户数据并推送到对话窗口中

btn.onclick = function () {

// alert(text.value)

//获取用户提交的内容

if (text.value.length === 0) {

alert('客官:是不是忘记输入内容了~~');

return false;

}

let userComment = text.value;


//立即清空用户信息区

text.value = '';


//创建一个新节点li

let li = document.createElement('li');

li.innerHTML = userComment;  //将用户输入的内容添加到新节点中

let userPic = '<img src="inc/peter.jpg" width="30" style="border-radius:50%">'; // 设置用户头像

li.innerHTML = userPic + ' ' + userComment; // 将用户头像与用户的聊天内容合并

list.appendChild(li); //发送聊天内容,实际上就是将新节点插入到对话列表中

sum += 1; // 聊天记录自增1


//设置定时器,默认2秒后会自动回复

setTimeout(function(){

let info = [

    '真烦人,有话快说,别耽误我玩抖音',

'除了退货,退款,咱们什么都可以聊',

'说啥,本姑娘怎么听不懂呢?再说一遍',

'在我方便的时候再回复你吧~~',

'投诉我的人多了,你算老几~~~'

];

let temp = info[Math.floor(Math.random()*3)];

//取1-5之间的一个整数:Math.floor(Math.random()*6 + 1)

let reply = document.createElement('li');

let kefuPic = '<img src="inc/zly.jpg" width="30" style="border-radius:50%;">';

// reply.innerHTML = '你有啥事呀,我的帅哥哥' +kefuPic

reply.innerHTML = kefuPic + ' ' + '<span style="color:red">'+temp+'</span>';


list.appendChild(reply);

sum += 1;


},2000);


// 当聊天记录达到10条时清空窗口

if (sum > 10) {

list.innerHTML = '';

sum = 0;

}

}



</script>

</body>

</html>


Correcting teacher:查无此人Correction time:2019-05-18 09:26:12
Teacher's summary:完成的不错,常用的css样式可以写到公用文件里,继续加油。

Release Notes

Popular Entries