position: relative;
}
div.box div.bottom span.delAll {
cursor: default;
}
div.box div.bottom div.js {
padding: 0 6px;
background-color: #00A5FF;
color: white;
margin-right: 10px;
cursor: default;
}
div.box div.bottom aside div {
display: inline-block;
}
div.box div.bottom aside div span {
position: absolute;
width: 50px;
line-height: 20px;
padding: 0 5px;
background-color: rgba(255, 255, 255, .4);
color: #333;
font-size: 10px;
margin-left: -60px;
margin-top: 20px;
transform: rotate(30deg);
cursor: pointer;
}
div.box div.bottom aside img {
height: 60px;
vertical-align: middle;
}
div.box div.bottom aside {
position: absolute;
background-color: #0a74cb;
width: 100%;
top: -70px;
padding: 5px;
box-sizing: border-box;
display: none;
}
div.box div.bottom aside.on {
display: block;
}
div.box div.bottom aside:after {
position: absolute;
content: “”;
border: 10px solid transparent;
border-top-color: #0a74cb;
bottom: -19px;
right: 280px;
}
div.box div.bottom a,
div.box div.bottom a:visited {
color: #0b97ff;
text-decoration: none;
}
js代码:
function $(exp) { //获取元素 #box
var el;
//对exp匹配以#开头的字符串,且匹配数字、字母、下划线、且以+结尾的字符串,如果存在该匹配,则返回true
if(/^#\w+$/.test(exp)) {
el = document.querySelector(exp);
} else {
el = document.querySelectorAll(exp);
}
return el;
}
var arr = []; /表单的数据,以数组存储/
arr[arr.length] = {
src: ‘1.jpg’,
txt: ‘Casio/卡西欧 EX-TR350’,
price: 5999.88
};
arr[arr.length] = {
src: ‘2.jpg’,
txt: ‘Canon/佳能 PowerShot SX50 HS’,
price: 3888.50
};
arr[arr.length] = {
src: ‘3.jpg’,
txt: ‘Sony/索尼 DSC-WX300’,
price: 1428.50
};
arr[arr.length] = {
src: ‘4.jpg’,
txt: ‘Fujifilm/富士 instax mini 25’,
price: 640.60
};
var temp = $(‘#temp’).innerHTML;
var tbody = $(‘#tbody’);
arr.forEach(function(el) { //把数据插入到HTML中 相当于初始化
tbody.innerHTML += temp.replace(“{src}”, el.src).replace(“{txt}”, el.txt).replace(“{price}”, el.price)
.replace(“{subtotal}”, el.price);
});
var trs = $(‘#tbody tr’);
var box = KaTeX parse error: Expected 'EOF', got '#' at position 3: ('#̲box');//():调用上面的函数
var aside = $(‘#bottom aside’)[0];
box.onclick = function(ev) {
//利用事件冒泡的原理,把事件添加给父级box
// var oEvent = ev || event; //意思是 ev 成立时 oEvent = event,否则 oEvent = ev
var e = ev || event;
//打印事件
console.log(“即将打印数据”);
console.log(e);
var target = e.target || e.srcElement; //获取当前点击对象
var cls = target.className;
if(cls.indexOf(“check”) != -1) cls = ‘check’;
switch(cls) {
case ‘add’: //添加商品数量
var tr = target.parentNode.parentNode; //找到点击过那一行
var tds = tr.cells;
target.previousSibling.value++; //数量那一栏的数字加一
tds[4].innerText = (tds[2].innerText * target.previousElementSibling.value).toFixed(2);
//修改小计里面的价格
break;
case ‘reduce’: //减少商品数量
//target:接受事件作用的DOM节点对象
var tr = target.parentNode.parentNode; //找到点击过那一行
//tr.cells:返回当前行的所有列
var tds = tr.cells;
/target.nextElementSibling.value:为标签后面的标签的值,target.nextElementSibling:当前标签的下一个兄弟标签/
if(target.nextElementSibling.value != 1) target.nextElementSibling.value–;
//数量那一栏减一 tds[4]:即为数量那一栏 tds[2]:单价 target.nextElementSibling.value:数量
tds[4].innerText = (tds[2].innerText * target.nextElementSibling.value).toFixed(2);
//修改小计里面的价格
break;
case ‘text’: //直接修改数量那一栏input的值
var tr = target.parentNode.parentNode;
var tds = tr.cells;
target.onblur = function() { //失去焦点时执行
// this:表示触发当前事件的对象
tds[4].innerText = (tds[2].innerText * this.value).toFixed(2);
// this.onblur:对离开当前DOM节点触发的事件进行销毁
this.onblur = null; //销毁事件
};
break;
case ‘del’: //删除商品
var tr = target.parentNode.parentNode;
if(confirm(‘你确定要删除吗?’))
tbody.removeChild(tr);
break;
case ‘check’: //复选框选择商品
chk(target); //执行复选框函数
break;
case ‘delAll’: //删除全部商品
if(confirm(‘你确定要删除吗?’))
tbody.innerHTML = ‘’;
break;
case ‘show’: //显示、隐藏商品
aside.classList.toggle(‘on’);
break;
case ‘cancel’:
var index = target.getAttribute(‘data-index’);
trs[index].cells[0].children[0].checked = false;
}
total(); //计算价格
};
var total_all = $(‘#total’);
var num = $(‘#num’);
total();
function total() { //计算价格
var sum = 0,
number = 0;
trs = $(‘tbody tr’);
var str = “”;
//i为索引,tr为对应 的索引的值
trs.forEach(
function(tr, i) {
//遍历每一行判断,将已选择商品添加到显示隐藏里面
var tds = tr.cells;
if(tds[0].children[0].checked) {
sum += parseFloat(tds[4].innerText);
number += parseInt(tds[3].children[1].value);
str += ‘
取消选择 ’;}
total_all.innerText = sum.toFixed(2);
num.innerText = number;
aside.innerHTML = str;
})
}
var checkAll = $(‘#box .checkAll’);//为第一行和最后一行的最左边的复选框
function chk(target) { //复选框判断
var cls = target.className;
var flag = true;
if(cls === ‘check’) { //点击非全选复选框
/当存在一个复选框未选中,全选框为false/
for(var i = 0; i < trs.length; i++) {
// var trs = $(‘#tbody tr’); 获取所有tbody里面的所有行
var checkbox = trs[i].cells[0].children[0];//获取里面的第一个
if(!checkbox.checked) { //如果没有被选中
flag = false;
break
}
}
checkAll[0].checked = checkAll[1].checked = flag;
} else { //点击全选复选框,所有复选框的状态保持一致
for(var i = 0; i < trs.length; i++) {
var checkbox = trs[i].cells[0].children[0];
checkbox.checked = target.checked;
}
//checkAll:为第一行和最后一行的最左边的复选框
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数同学面临毕业设计项目选题时,很多人都会感到无从下手,尤其是对于计算机专业的学生来说,选择一个合适的题目尤为重要。因为毕业设计不仅是我们在大学四年学习的一个总结,更是展示自己能力的重要机会。
因此收集整理了一份《2024年计算机毕业设计项目大全》,初衷也很简单,就是希望能够帮助提高效率,同时减轻大家的负担。
既有Java、Web、PHP、也有C、小程序、Python等项目供你选择,真正体系化!
由于项目比较多,这里只是将部分目录截图出来,每个节点里面都包含素材文档、项目源码、讲解视频
如果你觉得这些内容对你有帮助,可以添加VX:vip1024c (备注项目大全获取)
时,很多人都会感到无从下手,尤其是对于计算机专业的学生来说,选择一个合适的题目尤为重要。因为毕业设计不仅是我们在大学四年学习的一个总结,更是展示自己能力的重要机会。**
因此收集整理了一份《2024年计算机毕业设计项目大全》,初衷也很简单,就是希望能够帮助提高效率,同时减轻大家的负担。
[外链图片转存中…(img-Av3kfD5c-1712564153349)]
[外链图片转存中…(img-6qurwdZx-1712564153350)]
[外链图片转存中…(img-IGRhXpXO-1712564153351)]
既有Java、Web、PHP、也有C、小程序、Python等项目供你选择,真正体系化!
由于项目比较多,这里只是将部分目录截图出来,每个节点里面都包含素材文档、项目源码、讲解视频
如果你觉得这些内容对你有帮助,可以添加VX:vip1024c (备注项目大全获取)
[外链图片转存中…(img-6LJruahy-1712564153351)]