js代码与html代码分离示例

简介: 验证用户名是否存在的示例代码引出该思想:Insert title here            // 方式一:使用文本框的onblur事件(失去焦点事件)//         function ckName() {//             // 通过标签名获取元素节点对象//             var name = document.
验证用户名是否存在的示例代码引出该思想:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script type="text/javascript" src="${pageContext.request.contextPath}/js/myJS.js"></script>

<title>Insert title here</title>

    <script type="text/javascript">
        // 方式一:使用文本框的onblur事件(失去焦点事件)
//         function ckName() {
//             // 通过标签名获取元素节点对象
//             var name = document.getElementsByTagName("input")[0];
//             // 创建XMLHttpRequest对象
//             var xhr = getXMLHttpRequest();
//             // 处理响应结果,创建回调函数,根据响应状态动态更新页面
//             xhr.onreadystatechange = function() {
//                 if (xhr.readyState == 4) { // 说明客户端请求一切正常
//                     if (xhr.status == 200) { // 说明服务器响应一切正常
//                         // alert(xhr.responseText); // 得到响应结果,得到页面上面的结果,注意结果为字符串
//                         var msg = document.getElementById("msg");
//                         if (xhr.responseText == "true") {
//                             // msg.innerText = "用户名已存在";
//                             msg.innerHTML = "<font color='red'>该用户名已存在</font>";
//                         } else {
//                             msg.innerHTML = "<font color='green'>该用户名可以使用</font>";
//                         }
//                     }
//                 }
//             } 
//          

//             // 建立一个连接
//             xhr.open("get", "${pageContext.request.contextPath}/servlet/ckNameServlet?name=" + name.value);
//             // 发送请求
//             xhr.send(null);
//         }

        // 方式二:不使用文本框的事件
        // onload   加载完毕的事件,等到页面加载完毕后再执行onload事件所指向的函数。
        window.onload = function() {
            // 通过名获取元素对象
            var nameElement = document.getElementsByName("userName")[0];

            nameElement.onblur = function() {
                var name = this.value; // this等价于nameElement

                // 创建XMLHttpRequest对象
                var xhr = getXMLHttpRequest();
                // 处理响应结果,创建回调函数,根据响应状态动态更新页面
                xhr.onreadystatechange = function() {
                    if (xhr.readyState == 4) { // 说明客户端请求一切正常
                        if (xhr.status == 200) { // 说明服务器响应一切正常
                            // alert(xhr.responseText); // 得到响应结果,得到页面上面的结果,注意结果为字符串
                            var msg = document.getElementById("msg");
                            if (xhr.responseText == "true") {
                                // msg.innerText = "该用户名已存在";
                                msg.innerHTML = "<font color='red'>该用户名已存在</font>";
                            } else {
                                msg.innerHTML = "<font color='green'>该用户名可以使用</font>";
                            }
                        }
                    }
                }
           
                // 建立一个连接
                xhr.open("get""${pageContext.request.contextPath}/servlet/ckNameServlet?name=" + name + "&time=" + new Date().getTime());
                // 发送请求
                xhr.send(null);
            }
        }
    
</script>

</head>
<body>
    <!-- 文本框的onblur事件(失去焦点事件) -->
    <!-- 用户名:<input type="text" name="userName" onblur="ckName()"/><span id="msg" ></span></br> 
        为了使得页面的标签变得干净,事件不写在标签上。即js代码与html代码分离。
    -->

    用户名:<input type="text" name="userName" /><span id="msg" ></span></br>
    密码:<input type="password" name="pwd" /></br>
</body>
</html>

我的GitHub地址: https://github.com/heizemingjun
我的博客园地址: http://www.cnblogs.com/chenmingjun
我的蚂蚁笔记博客地址: http://blog.leanote.com/chenmingjun
Copyright ©2018 黑泽明军
【转载文章务必保留出处和署名,谢谢!】
相关文章
|
17天前
|
JSON JavaScript 前端开发
JavaScript原生代码处理JSON的一些高频次方法合集
JavaScript原生代码处理JSON的一些高频次方法合集
|
8天前
|
JavaScript 前端开发
js怎么删除html元素
js怎么删除html元素
23 10
|
8天前
|
前端开发
HTML代码示例
HTML代码示例
12 1
|
8天前
|
搜索推荐
当使用HTML代码时,一些常见的问题
当使用HTML代码时,一些常见的问题
9 0
|
9天前
错误或拦截页面的html代码
错误或拦截页面的html代码
14 0
错误或拦截页面的html代码
|
17天前
|
JSON JavaScript 前端开发
js是什么、html、css
js是什么、html、css
|
18天前
|
搜索推荐 前端开发 UED
html页面实现自动适应手机浏览器(一行代码搞定)
html页面实现自动适应手机浏览器(一行代码搞定)
18 0
|
1月前
|
JSON 前端开发 JavaScript
16个重要的JavaScript代码
16个重要的JavaScript代码
32 1
|
移动开发 前端开发 JavaScript
01_MUI之Boilerplate中:HTML5示例,动态组件,自定义字体示例,自定义字体示例,图标字体示例
 1安装HBuilder5.0.0,安装后的界面截图如下: 2 按照https://www.muicss.com/docs/v1/css-js/boilerplate-html中的说明,创建上图的Boilerplate.html: 3 代码内容如下: &lt;!--          作者:XXX@qq.com          时间:2015-08-02
1677 0
|
15天前
|
前端开发 JavaScript 开发工具
【HTML/CSS】入门导学篇
【HTML/CSS】入门导学篇
23 0