燕尾蝶乱舞 2016-04-11 10:25 采纳率: 50%
浏览 1740
已采纳

JavaScript onchange运行一次失效

载入时运行了一次,之后失效了,代码如下

add.jsp

 <%@page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<link rel="shortcut icon" type="image/x-icon" href="../favicon.ico" />
<title>添加</title>
<link href="/IMS/css/css.css" rel="stylesheet" type="text/css">
 <script src="/IMS/lib/MakeRequest.js"></script>
<script>
window.onload = initForm;

function initForm() {
     makeRequest(document.getElementById("aname"));
}
</script>
</head>
<body>
    <form action="Department111" method="post" name="add" id="add">
    <input type="hidden" name="action" value="add">
            <table>
                <tr>
                    <td width="120" align="right">名称:</td>
                    <td width="180" align="left"><input name="aname" type="text" id="aname" autofocus="autofocus" date="Department?action=s&name=" class="reqd"></td>
                </tr>
                <tr>
                    <td align="right">权限:</td>
                    <td align="left"><input name="level" id="level" class="reqd"></td>
                </tr>
                <tr>
                    <td align="right">
                            <a href="index.jsp">返回</a>
                        </td>
                    <td align="left"><input name="add" type="submit" id="add" value="添加"></td>
                </tr>
            </table>
    </form>
</body>
</html>

MakeRequest.js

function makeRequest(obj) {
    obj.addEventListener("onchange", makeR(obj), false)
    function makeR(obj) {
        console.log(obj);
        var url = obj.getAttribute("date") + obj.value;
        console.log(obj.value);
        console.log(url);
        if (window.XMLHttpRequest) {
            xhr = new XMLHttpRequest();
        } else {
            if (window.ActiveXObject) {
                try {
                    xhr = new ActiveXObject("Microsoft.XMLHTTP");
                } catch (e) {
                    console.log(e);
                }
            }
        }

        if (xhr) {
            xhr.addEventListener("readystatechange", showContents, false);
            xhr.open("GET", url, true);
            xhr.send(null);
        } else {
            msg.innerHTML = "Sorry, but I couldn't create an XMLHttpRequest";
        }
        function showContents() {
            if (xhr.readyState == 4) {
                if (xhr.status == 200) {
                    var outMsg = xhr.responseXML.getElementsByTagName("s")[0].childNodes[0].nodeValue;
                    if (outMsg == "yes") {
                        alert("已存在");
                    }
                } else {
                    var outMsg = "There was a problem with the request "
                            + xhr.status;
                    alert(outMsg);
                }
            }

        }
    }

}

  • 写回答

3条回答 默认 最新

  • Go 旅城通票 2016-04-12 01:30
    关注

    obj.addEventListener("onchange", makeR(obj), false)
    ==>
    obj.addEventListener("change", function(){makeR(obj)}, false)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器