导入代码(链接:https://pan.baidu.com/s/17v_dnXJTmo7QvFm-H58vaA 提取码:71wk)

1.JavaScrip实战1

鼠标悬浮和离开的效果设置

1)当鼠标悬浮时,显示背景颜色
在demon07.js中添加代码

//当鼠标悬浮时,显示背景颜色
function showBGColor(){
    //event:当前发生的事件
    //event.srcElement:事件源
    // alert(event.srcElement);
    // alert(event.srcElement.tagName);
    if(event && event.srcElement && event.srcElement.tagName=='TD'){
        var td = event.srcElement;
        //td.parentElement表示获取td的父元素 -- tr
        var tr = td.parentElement;
        //如果想要通过js代码设置某节点的样式,则需要加上 .style
        tr.style.backgroundColor = "navy";
        //tr.cells表示获取这个tr中的所有单元格
        var tds = tr.cells;
        for(var i = 0;i <= tds.length;i++){
            tds[i].style.color="white";
        }
    }
}

//当鼠标离开时,恢复原始样式
function clearBGColor(){
    if(event && event.srcElement && event.srcElement.tagName=='TD'){
        var td = event.srcElement;
        var tr = td.parentElement;
        tr.style.backgroundColor = "transparent";
        var tds = tr.cells;
        for(var i = 0;i <= tds.length;i++){
            tds[i].style.color="threeddarkshadow";
        }
    }
}

在tr标签上添加
οnmοuseοver=“showBGColor()” οnmοuseοut=“clearBGColor()”
如:

<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td >苹果</td>
						<td>5</td>
						<td>20</td>
						<td>100</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>
					<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td>西瓜</td>
						<td>3</td>
						<td>20</td>
						<td>60</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>
					<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td>菠萝</td>
						<td>4</td>
						<td>25</td>
						<td>100</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>
					<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td>榴莲</td>
						<td>3</td>
						<td>30</td>
						<td>90</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>

2)当鼠标悬浮在单元格时,显示手势
在demon07.js中添加代码

//当鼠标悬浮在单元格时,显示手势
function showHand(){
    if(event && event.srcElement && event.srcElement.tagName=='TD'){
        var td = event.srcElement;
        //cursor:光标
        td.style.cursor="hand";
    }
}

在需要添加效果的td标签处添加代码:οnmοuseοver=“showHand()”

<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td>苹果</td>
						<td onmouseover="showHand()">5</td>
						<td>20</td>
						<td>100</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>
					<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td>西瓜</td>
						<td onmouseover="showHand()">3</td>
						<td>20</td>
						<td>60</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>
					<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td>菠萝</td>
						<td onmouseover="showHand()">4</td>
						<td>25</td>
						<td>100</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>
					<tr onmouseover="showBGColor()" onmouseout="clearBGColor()">
						<td>榴莲</td>
						<td onmouseover="showHand()">3</td>
						<td>30</td>
						<td>90</td>
						<td><img src="imgs/del.jpg" class="delImg"/></td>
					</tr>

3)优化
删除html中的
οnmοuseοver=“showBGColor()” οnmοuseοut=“clearBGColor()”

οnmοuseοver=“showHand()”

在js文件中添加

window.onload = function(){
    //当也变加载完成,绑定各种事件
    //根据id获取到表格
    var fruitTbl = document.getElementById("tbl_fruit");
    //获取表格中的所有的行
    var rows = fruitTbl.rows;
    for(var i = 0;i < rows.length;i++){
        var tr = rows[i];
        //1.绑定鼠标悬浮设置及离开时的背景颜色事件
        tr.onmouseover=showBGColor;
        tr.onmouseout=clearBGColor;
        //获取tr这一行的所有单元格
        var cells = tr.cells;
        var priceTD = cells[1];
        //绑定鼠标悬浮在担架单元格变手势的时间
        priceTD.onmouseover=showHand;
    }
}

2.JavaScrip实战2

更新单价

修改js

window.onload = function(){
    updateZJ();
    //当也变加载完成,绑定各种事件
    //根据id获取到表格
    var fruitTbl = document.getElementById("tbl_fruit");
    //获取表格中的所有的行
    var rows = fruitTbl.rows;
    for(var i = 0;i < rows.length-1;i++){
        var tr = rows[i];
        //1.绑定鼠标悬浮设置及离开时的背景颜色事件
        tr.onmouseover=showBGColor;
        tr.onmouseout=clearBGColor;
        //获取tr这一行的所有单元格
        var cells = tr.cells;
        var priceTD = cells[1];
        //绑定鼠标悬浮在担架单元格变手势的时间
        priceTD.onmouseover=showHand;
        //3.绑定鼠标断点击单价单元格的事件
        priceTD.onclick=editPrice;
    }
}

//当鼠标点击单价单元格时进行价格编辑
function editPrice(){
    if(event && event.srcElement && event.srcElement.tagName=='TD'){
        var priceTD = event.srcElement;
        //目的是判断当前priceTD有子节点,且第一个子节点是文本节点,TextNode对应的是3,ElementNode对应的是1
        if(priceTD.firstChild && priceTD.firstChild.nodeType==3){
            //innerText表示设置或者获取当前节点的内部文本
            var oldPrice = priceTD.innerText;
            //innerHTML表示设置当前节点的内部HTML
            priceTD.innerHTML="<input type='text' size='4'/>";
            //<td><input type='text' size='4'/></td>
            var input = priceTD.firstChild;
            if(input.tagName=="INPUT"){
                input.value = oldPrice;
                //选中输入框内部的文本
                input.select();
                //4.绑定输入框失去焦点事件,失去焦点,更新单价
                input.onblur=updatePrice;
            }
        }
    }
}
//更新单价
function updatePrice(){
    if(event && event.srcElement && event.srcElement.tagName=='INPUT'){
        var input = event.srcElement;
        var newPrice = input.value;
        //input节点的父节点是td
        var priceTD = input.parentElement;
        priceTD.innerText = newPrice;

        //更新当前行的小计这一个格子的值
        //priceTD.parentElement td的父元素是tr
        updateXJ(priceTD.parentElement);
    }
}
//更新小计
function updateXJ(tr){
    if(tr && tr.tagName=="TR"){
        var tds = tr.cells;
        var price = tds[1].innerText;
        var count = tds[2].innerText;
        //innerText获取到的值的类型是字符串类型,因此需要类型转换,才能进行数学计算
        var xj = parseInt(price) * parseInt(count);
        tds[3].innerText = xj;

        //更新总计
        updateZJ();
    }
}
//更新总计
function updateZJ(){
    var fruitTbl = document.getElementById("tbl_fruit");
    var rows = fruitTbl.rows;
    var sum = 0;
    for(var i = 1;i < rows.length-1;i++){
        var tr = rows[i]; 
        var xj = parseInt(tr.cells[3].innerText);

        sum = sum + xj;
    }
    rows[rows.length-1].cells[1].innerText = sum;
}

3.JavaScrip实战3

删除指定的行

window.onload = function(){
    updateZJ();
    //当也变加载完成,绑定各种事件
    //根据id获取到表格
    var fruitTbl = document.getElementById("tbl_fruit");
    //获取表格中的所有的行
    var rows = fruitTbl.rows;
    for(var i = 0;i < rows.length-1;i++){
        var tr = rows[i];
        //1.绑定鼠标悬浮设置及离开时的背景颜色事件
        tr.onmouseover=showBGColor;
        tr.onmouseout=clearBGColor;
        //获取tr这一行的所有单元格
        var cells = tr.cells;
        var priceTD = cells[1];
        //绑定鼠标悬浮在担架单元格变手势的时间
        priceTD.onmouseover=showHand;
        //3.绑定鼠标断点击单价单元格的事件
        priceTD.onclick=editPrice;

        //7.绑定删除小图标的点击事件
        var img = cells[4].firstChild;
        if(img && img.tagName=="IMG"){
            //绑定点击事件
            img.onclick=delFruit;
        }
    }
}
//删除行
function delFruit(){
    if(event && event.srcElement && event.srcElement.tagName=='IMG'){
        //alert表示弹出一个对话框,只有确定按钮
        //confirm表示弹出一个对话框,有确定和取消按钮。当点击确定,返回true,否则false
        if(window.confirm("是否确认删除当前库存记录")){
            var img = event.srcElement;
            var tr = img.parentElement.parentElement;
            var fruitTbl = document.getElementById("tbl_fruit");
            fruitTbl.deleteRow(tr.rowIndex);

            updateZJ();
        }
    }
}

控制键盘的输入
修改js

//当鼠标点击单价单元格时进行价格编辑
function editPrice(){
    if(event && event.srcElement && event.srcElement.tagName=='TD'){
        var priceTD = event.srcElement;
        //目的是判断当前priceTD有子节点,且第一个子节点是文本节点,TextNode对应的是3,ElementNode对应的是1
        if(priceTD.firstChild && priceTD.firstChild.nodeType==3){
            //innerText表示设置或者获取当前节点的内部文本
            var oldPrice = priceTD.innerText;
            //innerHTML表示设置当前节点的内部HTML
            priceTD.innerHTML="<input type='text' size='4'/>";
            //<td><input type='text' size='4'/></td>
            var input = priceTD.firstChild;
            if(input.tagName=="INPUT"){
                input.value = oldPrice;
                //选中输入框内部的文本
                input.select();
                //4.绑定输入框失去焦点事件,失去焦点,更新单价
                input.onblur=updatePrice;

                //8.在输入框上绑定键盘按下的事件,此处我们需要保证用户输入的是数字
                input.onkeydown=ckInput;
            }
        }
    }
}
//检验键盘摁下的方法
function ckInput(){
    var kc = event.keyCode;
    //0~9:48~57
    //backspace:8
    //enter:13
    // console.log(kc);
    if(!((kc >= 48 && kc <=57) || kc == 8 || kc == 13)){
        event.returnValue=false;
    }
    if(kc == 13){
        event.srcElement.blur();
    }
}