中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jquery 版本的動態編輯表格 六

發布時間:2020-08-02 13:58:03 來源:網絡 閱讀:391 作者:huangyanxiong 欄目:web開發
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8"/>
    <title>練習</title>
</head>
<script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
<style type="text/css">
    .user{
        color: #DFDFDF;
    }
    table {
    border: 1px solid black;
    /*修正單元格之間的邊框不能合并*/
    border-collapse: collapse;
    width:600px;
    }
    table td {
        border: 1px solid black;
        width: 25%;
    }
    table th {
        border: 1px solid black;
        width: 25%;
    }
    tbody th {
        background-color: #A3BAE9; 
    }
</style>
<body>
    <div>
    <form name="form1" id="form1" >
        username:<input type="text" id="username" name='user'  />
        mail:<input type="text" id="mail" name="user" />
        phone:<input type="text" id="phone" name="user" />
        <input type="button" value="添加" id="add" />
    </form>
    </div>
    <div >
        <table  id="table">
            <tr>
                <th align="center" >username</th>
                <th align="center" >mail</th>
                <th align="center" >phone</th>
                <th align="center" >操作</th>
            </tr>
            <tr>
                <td align="center" class="userval">huangyanxiong</td>
                <td align="center" class="userval">huang@qq.com</td>
                <td align="center" class="userval">12345678912</td>
                <td align="center" class="userval">
                <input type="button" value="編輯" name="editInput" />
                <input type="button" value="刪除" name="delInput" />
                </td>
            </tr>
            <tr>
                <td align="center" class="userval">huangyanxiong</td>
                <td align="center" class="userval">huang@qq.com</td>
                <td align="center" class="userval">12345678912</td>
                <td align="center" class="userval">
                <input type="button" value="編輯" name="editInput" />
                <input type="button" value="刪除" name="delInput" />
                </td>
            </tr>
            <tr>
                <td align="center" class="userval">huangyanxiong</td>
                <td align="center" class="userval">huang@qq.com</td>
                <td align="center" class="userval">12345678912</td>
                <td align="center" class="userval">
                    <input type="button" value="編輯" name="editInput" />
                    <input type="button" value="刪除" name="delInput" />
                </td>
            </tr>
        </table>
    </div>
</body>
<script type="text/javascript">
    $(document).ready(function(){
        /*
            1版后話:這樣會存在一個問題就是表格中已經存在一些原有的表格行數據并且沒有按過添加按鈕時時就不能進行編輯和刪除,需要對代碼進行調整
            2版問題:這樣會造成點擊一次編輯或者刪除按鈕會變成兩次按鈕,而且代碼不能復用
            3版(this):利用函數解決代碼復用,但是jquery不支持這樣做
            4版使用jquery的插件方案,解決代碼不能復用的問題,但是沒有解決點擊一次變成兩次的問題
            5將1234版遺留問題解決,解決方法就是 采用jquery的事件委派來解決---live();jQuery 給所有匹配的元素附加一個事件處理函數,即使這個元素是以后再添加進來的也有效。
            6版:新增功能雙擊可以編輯表格失敗告終,搞出一堆問題,事件委派的特點會將所有元素都添加上事件,還有最后一個問題
        */
        /*
            委派點擊事件給選擇器匹配的編輯按鈕
        */
        $('input[name="editInput"]').live('click',function(){
            var i=1;
            if ($(this).val()=='編輯') {
            $(this).parent().siblings().each(function(){
                $(this).html('<input type="text" value='+'"'+$(this).text()+'"'+''+' />');
                    i++;
                });
                $(this).val('保存');
                return false;
            };
            if ($(this).val()=='保存') {
                $(this).parent().siblings().each(function(){
                    $(this).text($(this).children().val());
                i++;
                });
                $(this).val('編輯');
                return false;
            };
        });
        /*
            委派點擊事件給選擇器匹配刪除按鈕
        */
        $('input[name="delInput"]').live('click',function(){
            if (confirm('確定要刪除嗎')) {
                $(this).parent().parent().remove();  //jquery最大特點可以自己刪除自己
            };
        });
        /*
                給添加按鈕定義一個點擊事件,并且獲取用戶值創建表格行進行存儲
        */
        $('#add').click(function(){
            var td=new Array();
            var editInput="<input type='button' value='編輯' name='editInput'/>";
            var delInput="<input type='button' value='刪除' name='delInput'/>";
            var i=0;
              
            $("input[name='user']").each(function(){
                td[i]="<td align='center'>"+$(this).val()+"</td>";  //專門獲取屬性值
                i++;
            });
            $('#table').append('<tr>'+td.join('')+"<td align='center'>"+editInput+' '+delInput+"</td>"+'</tr>');
        });
        //找到所有的需要綁定事件的td并且把這些td里面含有input 元素的td排除,并且委派雙擊事件  find()方法適合找個一個元素里面包含的元素
        /*Uncaught Error: Syntax error, unrecognized expression: td[align="center"].not([object Object]) jquery-1.8.3.min.js:2
        nt.error jquery-1.8.3.min.js:2
        ut jquery-1.8.3.min.js:2
        vt jquery-1.8.3.min.js:2
        g.querySelectorAll.vt jquery-1.8.3.min.js:2
        nt jquery-1.8.3.min.js:2
        v.event.dispatch jquery-1.8.3.min.js:2
        v.event.add.o.handle.u
        */
        var editTd=$('td[align="center"]').not($('td[align="center"]').find('input').parent());
        console.info(editTd);
        editTd.live('click',function(){
            alert(123456);
        });
    });
</script>
</html>


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

张家川| 寿光市| 兴仁县| 秭归县| 雅江县| 镇远县| 合江县| 固镇县| 北碚区| 绍兴市| 堆龙德庆县| 罗定市| 伊春市| 刚察县| 化德县| 柳州市| 安宁市| 石景山区| 海安县| 东方市| 深泽县| 苏尼特左旗| 蓝田县| 出国| 台北市| 五台县| 鄂托克前旗| 信丰县| 永修县| 兴国县| 普兰县| 布拖县| 滕州市| 阜宁县| 南涧| 安岳县| 西乌珠穆沁旗| 阿城市| 雷波县| 监利县| 渝北区|