前言
有关bom的小案例
百度换肤
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
img{
width: 300px;
}
div{
margin: 200px;
}
</style>
</head>
<body>
<div>
<img src="1.jpg" alt="">
<img src="2.jpg" alt="">
<img src="12.jpg" alt="">
</div>
<script>
var img=document.querySelectorAll('img')
console.log(img[0].src);
for(var i=0;i<img.length;i++){
img[i].onclick=function(){
var body=document.body;
//后面就是要加的所有内容
body.style.backgroundImage='url('+this.src+')'
}
}
</script>
</body>
</html>
表格变色
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
table {
width: 800px;
margin: 100px auto;
text-align: center;
border-collapse: collapse;
font-size: 14px;
}
thead tr {
height: 30px;
background-color: skyblue;
}
tbody tr {
height: 30px;
}
tbody td {
border-bottom: 1px solid #d7d7d7;
font-size: 12px;
color: blue;
}
</style>
</head>
<body>
<table>
<thead>
<th>代码</th>
<th>名称</th>
<th>净值</th>
<th>增幅</th>
<th>增长率</th>
</thead>
<tbody>
<tr>
<td>0326</td>
<td>A股</td>
<td>1.075</td>
<td>1.074</td>
<td>85%</td>
</tr>
<tr>
<td>0326</td>
<td>A股</td>
<td>1.075</td>
<td>1.074</td>
<td>85%</td>
</tr>
<tr>
<td>0326</td>
<td>A股</td>
<td>1.075</td>
<td>1.074</td>
<td>85%</td>
</tr>
<tr>
<td>0326</td>
<td>A股</td>
<td>1.075</td>
<td>1.074</td>
<td>85%</td>
</tr>
</tbody>
</table>
<script>
var tr=document.querySelector('tbody').querySelectorAll('tr');
console.log(tr);
for(var i=0;i<tr.length;i++){
tr[i].onmouseover=function(){
this.style.backgroundColor='pink'
}
tr[i].onmouseleave=function(){
this.style.backgroundColor=''
}
}
</script>
</body>
</html>
表格全选
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
* {
padding: 0;
margin: 0;
}
.wrap {
width: 300px;
margin: 100px auto 0;
}
table {
border-collapse: collapse;
border-spacing: 0;
border: 1px solid #c0c0c0;
width: 300px;
}
th,
td {
border: 1px solid #d0d0d0;
color: #404060;
padding: 10px;
}
th {
background-color: #09c;
font: bold 16px "微软雅黑";
color: #fff;
}
td {
font: 14px "微软雅黑";
}
tbody tr {
background-color: #f0f0f0;
}
tbody tr:hover {
cursor: pointer;
background-color: #fafafa;
}
</style>
</head>
<body>
<div class="wrap">
<table>
<thead>
<tr>
<th>
<input type="checkbox" id="j_cbAll" />
</th>
<th>商品</th>
<th>价钱</th>
</tr>
</thead>
<tbody id="j_tb">
<tr>
<td>
<input type="checkbox" />
</td>
<td>iPhone8</td>
<td>8000</td>
</tr>
<tr>
<td>
<input type="checkbox" />
</td>
<td>iPad Pro</td>
<td>5000</td>
</tr>
<tr>
<td>
<input type="checkbox" />
</td>
<td>iPad Air</td>
<td>2000</td>
</tr>
<tr>
<td>
<input type="checkbox" />
</td>
<td>Apple Watch</td>
<td>2000</td>
</tr>
</tbody>
</table>
</div>
<script>
var thin=document.getElementsByTagName('thead')[0].getElementsByTagName('input')
var trin=document.getElementsByTagName('tbody')[0].getElementsByTagName('input')
//用上面的按钮影响下面的按钮.上面按钮索引为0,下面按钮从1开始
thin[0].onclick=function(){
console.log(this.checked);
for(var i=0;i<trin.length;i++){
trin[i].checked=this.checked;
}
}
2.下面复选框需要全部选中,上面全选才能选中做法:给下面所有复选框绑定点击事件,每次点击,都要判断是否全部选中)
for(i=0;i<trin.length;i++){
trin[i].onclick=function(){
var flag=true;
//检查是否全部选中
for(var i=0;i<trin.length;i++){
if(!trin[i].checked){
flag=false;
break;
}
}
thin[0].checked=flag
}
}
</script>
</body>
</html>
动态添加表格数据
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
table{
width: 500px;
margin: 100px auto;
border-collapse: collapse;
text-align: center;
}
td,th{
border: 1px solid #333;
}
thead tr{
height: 40px;
background-color: #ccc;
}
</style>
</head>
<body>
<table cellspacing="0">
<thead>
<tr>
<th>姓名</th>
<th>科目</th>
<th>成绩</th>
<th>操作</th>
</tr>
</thead>
<tbody></tbody>
</table>
<script>
//准备数据
var date=[{
name:'卫英络',
subject:'javascript',
score:100
},{
name:'弘历',
subject:'javascript',
score:100
},{
name:'富恒',
subject:'javascript',
score:100
},{
name:'明宇',
subject:'javascript',
score:100
}]
//往body里先加行再加列
var tbody=document.querySelector('tbody');
for(var i=0;i<date.length;i++){//管行
//创建好多行
var tr=document.createElement('tr');
//添加
tbody.appendChild(tr);
//创建列,遍历对象的属性值
for(k in date[i]){
var td=document.createElement('td');
//先赋值再添加
td.innerHTML=date[i][k];
tr.appendChild(td);
}
var td1=document.createElement('td');
tr.appendChild(td1);
td1.innerHTML='<a href="javascript:;">删除</a>'
}
//添加事件 链接
var as=document.querySelectorAll('a')
for(var i=0;i<as.length;i++){
as[i].onclick=function(){
tbody.removeChild(this.parentNode.parentNode)
}
}
</script>
</body>
</html>
留言板
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.yan{
width: 300px;
height: 100px;
}
li{
width: 300px;
background-color: rgb(231, 185, 17);
}
li a{
float: right;
}
</style>
</head>
<body>
<input type="text" class="yan">
<button>提交</button>
<ul>
</ul>
<script>
var message=document.querySelector('input');
var bnt=document.querySelector('button')
var ul=document.querySelector('ul')
bnt.onclick=function(){
console.log(message.value);
//添加
var li=document.createElement('li')
li.innerHTML=message.value+'<a href="javascript:;">删除</a>'
//插入
ul.insertBefore(li,ul.children[0]);
var li=document.querySelector('li');
//删除
//获取a;删除a对应的li
var as=document.querySelectorAll('a');
for(var i=0;i<as.length;i++){
as[i].onclick=function(){
//删除this.parentNode
ul.removeChild(this.parentNode)
}
}
}
</script>
</body>
</html>
密码明文
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.box1{
position: relative;
width: 400px;
border-bottom: 1px solid #ccc;
margin: 100px auto;
}
.box1 input{
width: 370px;
height: 30px;
border: 0;
outline: none;
}
.box1 img{
position: absolute;
top: 2px;
right: 2px;
width: 30px;
}
</style>
</head>
<body>
<div class="box1">
<lable for="">
<img src="close.png" alt="">
</lable>
<input type="password" name="pwd" id="pwd">
</div>
<script>
var pwd=document.querySelector('input');
var img=document.querySelector('img');
var flag=0;//可以多次点击
img.onclick=function(){
if(flag==0){
pwd.type='text';
img.src='open.png';
flag=1;
}else{
pwd.type='password';
img.src='close.png';
flag=0
}
}
</script>
</body>
</html>
新浪下拉菜单
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
* {
margin: 0;
padding: 0;
}
li {
list-style-type: none;
}
a {
text-decoration: none;
font-size: 14px;
}
.nav {
margin: 100px;
}
.nav>li {
position: relative;
float: left;
width: 80px;
height: 41px;
text-align: center;
}
.nav li a {
display: block;
width: 100%;
height: 100%;
line-height: 41px;
color: #333;
}
.nav>li>a:hover {
background-color: #eee;
}
.nav ul {
display: none;
position: absolute;
top: 41px;
left: 0;
width: 100%;
border-left: 1px solid #FECC5B;
border-right: 1px solid #FECC5B;
}
.nav ul li {
border-bottom: 1px solid #FECC5B;
}
.nav ul li a:hover {
background-color: #FFF5DA;
}
</style>
</head>
<body>
<ul class="nav">
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
</ul>
<script>
var ul=document.querySelector('.nav')
var lis=ul.children;//四个li
// console.log(lis);
for(var i=0;i<lis.length;i++){
// console.log(lis[i]);
lis[i].onmouseover=function(){
this.children[1].style.display='block'
}
lis[i].onmouseleave=function(){
this.children[1].style.display='none'
}
}
</script>
</body>
</html>