模拟在线客服

Original 2019-01-16 15:22:38 240
abstract:<html lang="en">    <head>     <meta charset="UTF-8">     <title>DOM实战:模拟智能在线客服系统</title>     <style type=&

<html lang="en">    

<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 align="right"><textarea cols="50" rows="4" name="text"></textarea></td>    

<td align="left"><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-01-16 15:36:55
Teacher's summary:难道非要我把你的作业打回去,你才会发现问题么?这样看视频意义何在?学到东西了么?就不说你的作业有没有按时按量完成,你这样也太敷衍了吧?你的每一个作业老师都有认真看,也提示很多次作业不符合标准,怕耽误你进度,所以一直比较宽松,你这不是在浪费我感情么??

Release Notes

Popular Entries