JavaScript- 操作元素案例
Posted 我真的爱敲代码
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript- 操作元素案例相关的知识,希望对你有一定的参考价值。
操作元素
排他思想案例
1. 背景换肤案例
这个案例练习的是给一组元素注册事件
给4个小图片利用循环注册点击事件
当点击了这个图片,让页面背景改为当前的图片
核心算法: 把当前图片的src 路径取过来,给 body 做为背景即可
<style>
* {
margin: 0;
padding: 0;
}
body {
background: url(img/今天也要加油鸭.jpg) no-repeat center top;
}
li {
list-style: none;
}
.yemian {
overflow: hidden;
margin: 100px auto;
background-color: #fff;
width: 40px;
padding-top: 3px;
}
.yemian li {
float: left;
margin: 0 1px;
cursor: pointer;
}
.yemian img {
width: 100px;
}
</style>
</head>
<body>
<ul class="yemian">
<li><img src="./img/今天不想加油鸭.jpg"></li>
<li><img src="./img/今天也要加油鸭.jpg"></li>
<li><img src="./img/特警.jpg"></li>
<li><img src="./img/鸭子.jpg"></li>
</ul>
<script>
// 1.获取元素
var imgs = document.querySelector('.yemian').querySelectorAll('img')
// 2.循环注册事件
for (var i = 0; i < imgs.length; i++) {
imgs[i].onclick = function () {
document.body.style.backgroundImage = 'url(' + this.src + ')'
}
}
</script>
</body>
2. 表格隔行变色案例
用到新的鼠标事件 鼠标经过 onmouseover 鼠标离开 onmouseout
核心思路:鼠标经过 tr 行,当前的行变背景颜色, 鼠标离开去掉当前的背景颜色
注意: 第一行(thead里面的行)不需要变换颜色,因此我们获取的是 tbody 里面的行
<body>
<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;
}
.bg {
background-color: gray;
}
</style>
<table>
<thead>
<tr>
<th>代码</th>
<th>名称</th>
<th>最新公布净值</th>
<th>累计净值</th>
<th>前单位净值</th>
<th>净值增长率</th>
</tr>
</thead>
<tbody>
<tr>
<th>003526</th>
<th>农银金穗3个月定期开放债券</th>
<th>1.075</th>
<th>1.079</th>
<th>1.074</th>
<th>+0.047%</th>
</tr>
<tr>
<th>270047</th>
<th>广发理财</th>
<th>0.903</th>
<th>3.386</th>
<th>0.000</th>
<th>0.000%</th>
</tr>
<tr>
<th>163417</th>
<th>兴全合宜</th>
<th>0.860</th>
<th>0.860</th>
<th>0.863</th>
<th>-0.382%</th>
</tr>
<tr>
<th>003929</th>
<th>中银证券</th>
<th>1.034</th>
<th>1.088</th>
<th>1.034</th>
<th>+0.077%</th>
</tr>
</tbody>
</table>
<script>
// 1.获取元素:tbody里面所有的行
var trs = document.querySelector('tbody').querySelectorAll('tr')
// 2. 利用循环绑定注册时间
for (var i = 0; i < trs.length; i++) {
// 3.鼠标经过事件
trs[i].onmouseover = function () {
this.className = 'bg'
}
// 4. 鼠标离开事件
trs[i].onmouseout = function () {
this.className = ''
}
}
</script>
</body>
3. 表单全选取消案例
业务需求:
- 点击上面全选复选框,下面所有的复选框都选中(全选)
- 再次点击全选复选框,下面所有的复选框都不中选(取消全选)
- 如果下面复选框全部选中,上面全选按钮就自动选中
- 如果下面复选框有一个没有选中,上面全选按钮就不选中
- 所有复选框一开始默认都没选中状态
分析:
- 全选和取消全选做法: 让下面所有复选框的checked属性(选中状态) 跟随 全选按钮即可
- 下面复选框需要全部选中, 上面全选才能选中做法: 给下面所有复选框绑定点击事件,每次点击,都要循环查看下面所有的复选框是否有没选中的,如果有一个没选中的, 上面全选就不选中。
- 可以设置一个变量,来控制全选是否选中
<body>
<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 th {
background-color: #f0f0f0;
color: #404060;
}
tbody tr:hover {
cursor: pointer;
background-color: #fafafa;
}
</style>
<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>
<th>
<input type="checkbox">
</th>
<th>荣耀20</th>
<th>2799</th>
</tr>
<tr>
<th>
<input type="checkbox">
</th>
<th>小米</th>
<th>2699</th>
</tr>
<tr>
<th>
<input type="checkbox">
</th>
<th>oppo</th>
<th>2699</th>
</tr>
<tr>
<th>
<input type="checkbox">
</th>
<th>vivo</th>
<th>2699</th>
</tr>
</tbody>
</table>
</div>
<script>
// 全选和取消全选
// 1. 获取元素
var j_cbAll = document.getElementById('j_cbAll') //全选按钮
var j_tbs = document.getElementById('j_tb').getElementsByTagName('input') //下面所有的复选框
// 注册事件
j_cbAll.onclick = function () {
// this.checked可以得到当前复选框的选中状态,true则为选中
console.log(this.checked)
for (var i = 0; i < j_tbs.length; i++) {
j_tbs[i].checked = this.checked //!!!关键点,一定要搞懂
}
}
// 下面复选按钮影响上面的全选按钮
for (var i = 0; i < j_tbs.length; i++) {
j_tbs[i].onclick = function () {
// flag -->控制全选按钮是否选中
var flag = true
// 每次点击下面的复选框都要循环检查4个小按钮是否被全选中
for (var i = 0; i < j_tbs.length; i++) { //该for循环包含在上一个function函数中,属于不同的作用域,两个i不受影响
if (!j_tbs[i].checked) { //对该按钮取反则表示该按钮没有被选中。默认全部都是未选中,所以第一次选中得到的是true
//j_cbAll.checked = false //因为存在按钮没有被选中,所以让全选按钮改成flase
flag = false
break //退出for循环,提高执行效率。只要有一个没选中就不用再继续判断,就无意义了
}
}
j_cbAll.checked = flag
}
}
</script>
</body>
自定义属性案例
1.tab栏切换(重点案例)
当鼠标点击上面相应的选项卡(tab),下面的内容跟随变化
案例分析:
- Tab栏切换有2个大的模块
- 上面的模块选项卡,点击某一个,当前这一个底色会是红色,其余不变(排他思想) 修改类名的方式
- 下面的模块内容,会跟随上面的选项卡变化。所以下面模块变化写到点击事件里面。
- 规律:下面的模块显示内容和上面的选项卡一一对应,相匹配。
- 核心思路: 给上面的tab_list 里面的所有小li 添加自定义属性,属性值从0开始编号。
- 当点击tab_list 里面的某个小li,让tab_con 里面对应序号的 内容显示,其余隐藏(排他思想)
<body>
<style>
* {
margin: 0;
padding: 0;
}
li {
list-style-type: none;
}
.tab {
width: 978px;
margin: 100px auto;
}
.tab_list {
height: 39px;
border: 1px solid #ccc;
background-color: #f1f1f1;
}
.tab_list li {
float: left;
height: 39px;
line-height: 39px;
padding: 0 20px;
text-align: center;
cursor: pointer;
}
.tab_list .current {
background-color: #c81623;
color: #fff;
}
.item_info {
padding: 20px 0 0 20px;
}
.item {
display: none;
}
</style>
<div class="tab">
<div class="tab_list">
<ul>
<li class="current">商品介绍</li>
<li>规格与包装</li>
<li>售后保障</li>
<li>商品评价(50000)</li>
<li>手机社区</li>
</ul>
</div>
<div class="tab_con">
<div class="item" style="display: block;">
商品介绍模块内容
</div>
<div class="item">
规以上是关于JavaScript- 操作元素案例的主要内容,如果未能解决你的问题,请参考以下文章