批改状态:合格
老师批语:
通过两次js课堂学习和实战案例完成,我认识到,对一一个好的,或者说功能强大的网站页面来说,js脚本是必不可少的,学好js很重要。
0330JavaScript实战2(实战1:选项卡)代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>实战1:选项卡</title>
<head>
<style type="text/css">
h2 {
text-align: center;
}
.box {
width: 538px;
height: 500px;
background-color: white;
border: 1px solid #ccc;
margin: 20px auto;
color: #363636;
}
.box > ul {
margin: 0;
padding: 0;
background-color: #f8f8f8;
/*border-bottom: 1px solid #ccc;*/
overflow: hidden;
}
.box > ul li {
list-style-type: none;
width: 90px;
height:36px;
float:left; border-right: 1px solid #ccc;
border-bottom: 1px solid #ccc;
text-align: center;
line-height: 36px;
}
.box ul + span {
float:right;
width:90px;
height: 36px;
line-height: 36px;
margin-top: -36px;
}
.box ul + span >a {
color: #696969;
text-decoration: none;
} .box li.active {
background-color: #fff;
font-weight: bolder;
border-bottom: none; border-top: 3px solid orangered;
} .box div {
display: none;
} .box div ul {
margin: 0;
padding: 10px; list-style-type: none;
}
.box div ul li {
line-height: 1.5em;
/*background-color: yellow;*/
} .box div ul li a {
color: #636363;
text-decoration: none;
}
.box div ul li a:hover {
color: #000;
} .box div ul li span {
float: right;
color: red; }
</style>
</head>
<body>
<body>
<h2>仿PHP中文网选项卡实战</h2>
<div>
<ul>
<!-- 创建四个选项卡,并设置第一个为当前激活高亮状态 -->
<li class="">技术文章</li>
<li>网站源码</li>
<li class="">原生手册</li>
<li class="">推荐博文</li>
</ul>
<span><a href="">更多下载>></a></span> <!-- 其实在页面中看到列表,其实都已经在页面中了,只是隐藏了起来,实际开发过程,大多是通过Ajax请求来动态获取 -->
<div style="display: none;">
<ul>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
<li><a href="">PHP教程 | PHP生成带logo图像二维码的两种方法</a><span>03-30</span></li>
</ul>
</div> <div style="display: block;">
<ul>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
<li><a href="">前端模板 | Bootstrap响应式网站后台管理面板</a><span>03-30</span></li>
</ul>
</div> <div style="display: none;">
<ul>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
<li><a href="">原生手册 | CentOS7安装MySQL5.7密码查看与修改</a><span>03-30</span></li>
</ul>
</div>
<div style="display: none;">
<ul>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
<li><a href="">无耻的鱼 | javascript初体验之图片切换与计算机</a><span>03-30</span></li>
</ul>
</div>
</div>
<script type="text/javascript">
//1. 获取选项卡与对应显示的内容区块对象
var box = document.getElementsByClassName('box')[0]
//该方法是根据标签名来获取元素,因为页面中可以多个同名标签,所以返回的也是一个数组,要加[0]指定元素
var ul = box.getElementsByTagName('ul')[0]
//该方法是根据标签名来获取元素,因为页面中可以多个同名标签,所以返回的也是一个数组,要加[0]指定元素
var tab = ul.getElementsByTagName('li')
//获取到页面全部的信息列表,当然返回的也是一个数组
var list = box.getElementsByTagName('div')
// alert(tab.length) //选项卡的数量
//给每一个选项卡添加事件,因为有四个选项卡,所以要用到循环
//这段循环是用来清空当前用户的所有操作
for (var i=0; i<tab.length; i++) {
tab[i].index = i
tab[i].onmouseover = function (){
//清空标签的样式并将当前对列表隐藏
for (var i=0; i<tab.length; i++) { //第一步: 将除了当前选项卡之外的所有标签样式全部清空
tab[i].className = '' //第二步: 将除了当前信息列表之外的列表全部隐藏
list[i].style.display = 'none'
}
//设置用户当前操作的选项卡为高亮显示
this.className = 'active'
//将对应的信息列表显示出来:直接修改其display属性为block即可
list[this.index].style.display = 'block'
}
}
</script>
</body>
</html>0330JavaScript实战2(实战1:选项卡)效果:

0330JavaScript实战2(实战: 仿机器人聊天窗口)代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>实战: 仿机器人聊天窗口</title>
<style type="text/css">
div:nth-child(1) {
width: 450px;
height: 650px;
background-color: lightgreen;
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 blue;
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>
<body>
<div>
<h2>在线客服</h2>
<div contenteditable="true">
<ul>
<li></li>
</ul>
</div>
<table>
<tbody><tr>
<td><textarea cols="50" rows="4" name="text"></textarea></td>
<td><button type="button">发送</button></td>
</tr>
</tbody></table>
</div>
<script type="text/javascript">
//获取到页面中的按钮,文本域,对话内容区
var btn = document.getElementsByTagName('button')[0]
var text = document.getElementsByName('text')[0]
var list = document.getElementsByTagName('ul')[0]
var sum = 0 //添加按钮点击事件,获取用户数据并推送到对话窗口中
btn.onclick = function () {
// alert(text.value)
//获取用户提交的内容
if (text.value.length == 0) {
alert('客官:是不是忘记输入内容了~~')
return false
}
var userComment = text.value //立即清空用户信息区
text.value = '' //创建一个新节点li
var li = document.createElement('li')
li.innerHTML = userComment var userPic = '<img src="../images/fbb.jpg" width="30" style="border-radius:50%">'
li.innerHTML = userPic+userComment //将新节点插入到对话列表中
list.appendChild(li)
sum += 1
setTimeout(function(){
var info = ['你好烦人呀,本姑娘好累,不知道怜香惜玉吗?','除了退货,退款,维修,什么问题都可以问','啥事呀,我的帅哥哥']
var temp = info[Math.floor(Math.random()*3)]
//取1-5之间的一个整数:Math.floor(Math.random()*6 + 1)
var reply = document.createElement('li')
var kefuPic = '<img src="../images/zly.jpg" width="30" style="border-radius:50%;">'
// reply.innerHTML = '你有啥事呀,我的帅哥哥' +kefuPic
reply.innerHTML = kefuPic + '<span style="color:red">'+temp+'</span>'
// reply.style.float = 'right' list.appendChild(reply)
sum += 1 },2000)
if (sum > 10) {
list.innerHTML = ''
sum = 0
} }
</script>
</body>
</html>0330JavaScript实战2(实战: 仿机器人聊天窗口)效果:

总结:通过对(实战1:选项卡、.实战: 仿机器人聊天窗口)两个实战案例的学习,我对js 的认识和理解跟深刻了,了解到很多页面都会涉及用到选项卡,学会了简单选项卡的js写法。也学会了简单的客服聊天的简单实现。加深了对js的了解和用户情况。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号