国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript實現按回車鍵切換焦點

2019-11-20 13:12:17
字體:
來源:轉載
供稿:網友

前段時間學習了 HTML 和 CSS,對這方面產生了興趣,也開始學習了 javascript 高級編程(第三版),這些天也一直在學,剛剛學到事件和表單腳本的內容。前幾天,老師讓編寫一段代碼:是在 javascript 表單中,用回車鍵和上下左右移動鍵使焦點從一個文本框移到上一個或下一個文本框中。應用目前為止學到的知識試著編寫代碼,在編寫的過程中遇到了幾個難點:取模計算;在函數內部用 this 和 arguments 找到觸發事件;使用 addHandler() 方法為事件添加事件處理程序。在老師的幫助下解決了以上幾個問題,自己覺得通過這段代碼學到了很多知識點,所以整理完后寫上注釋,發表一下下。

復制代碼 代碼如下:

<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
</head>
<body>
    <form>
        <div><input type="text" ></div>
        <div><input type="text" ></div>
        <div><input type="text" ></div>
        <div><input type="text" ></div>
        <div><input type="text" ></div>
        <div><input type="submit" ></div>
    </form>
    <script>
        function is_down(e) {
            var isDown;
            e = e || window.event;
            switch (e.keyCode) {
                case 13:  //回車鍵
                case 39:  //向右移動鍵
                case 40:  //向下移動鍵
                    isDown = true;
                    break;
                case 37:  //向左移動鍵
                case 38:  //向上移動鍵
                    isDown = false;
                    break;
            }
            return isDown;
        }
        function key_up(){
            //調用函數時,函數本身會生成 this 和 arguments
            //用 this 和 arguments 分別找到 field 和觸發的事件
            var e=arguments[1];
            return is_down(e) === undefined ? true : handle_element(this, is_down(e));
        }
        function handle_element(field, is_down) {
            var elements = field.form.elements;
            for (var i = 0, len = elements.length-1; i < len; i++) {
                if (field == elements[i]) {
                    break;
                }
            }
            i = is_down ? (i + 1) % len : (i - 1) % len;
            //(0===i && is_down) --> 最后一個文本框獲得焦點后按向下的鍵
            //(-1===i && !is_down) --> 第一個文本框獲得焦點后按向上的鍵
            if((0===i && is_down)||(-1===i && !is_down)){
                return true;
            }
            elements[i].focus();
            var element_arr = ['button', 'submit', 'reset', 'select-one', 'textarea'];
            if (element_arr.join(',').indexOf(elements[i].type) > -1)
                elements[i].select();
            return false;
        }
        //取消回車默認提交表單事件
        document.onkeydown = function(e) {
            e = e || window.event;
            if(e.keyCode == 13) {
                e.preventDefault ? e.preventDefault() : (e.returnValue = false);
            }
        };
        //跨瀏覽器識別 addEventListener 和 attachEvent(IE)
        function addHandler(element, type, handler) {
            if (element.addEventListener)
                element.addEventListener(type, handler, false);
            else if (element.attachEvent)
                element.attachEvent("on" + type, handler);
            else
                element["on" + type] = handler;
        }
        var elements = document.forms[0].elements;
        for (var i = 0, len = elements.length; i < len; i++) {
            //為 keyup 事件添加 key_up 事件處理程序
            addHandler(elements[i], "keyup", key_up);
        }
    </script>
</body>
</html>

以上就是代碼的全部內容了,個人感覺寫的還算比較全面,該考慮到的地方都做了處理,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 洪泽县| 通江县| 沾益县| 敦化市| 长岭县| 平江县| 深泽县| 岑巩县| 蓬莱市| 西青区| 呼伦贝尔市| 马边| 包头市| 武宁县| 肥东县| 天台县| 正安县| 忻城县| 垫江县| 东阿县| 侯马市| 阿拉善盟| 仪征市| 富民县| 高雄县| 通化市| 罗山县| 合水县| 平阳县| 陆河县| 固原市| 综艺| 徐水县| 南开区| 红原县| 砀山县| 哈巴河县| 邵阳县| 甘孜县| 山阴县| 乌拉特中旗|