springMVC_Ajax小案例

案例1:post传参并返回值

名字为admin跳出true弹框,可运用于表单信息验证
springMVC_Ajax小案例_第1张图片

第一步:写controller接口:

  @RequestMapping({
     "/a1"})
    public void ajax1(String name, HttpServletResponse response) throws IOException {
     
        if ("admin".equals(name)) {
     
            response.getWriter().print("true");
        } else {
     
            response.getWriter().print("false");
        }
    }

第二步编写前端界面:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
  <title>$Title$</title>
  <%--<script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>--%>
  <script src="${pageContext.request.contextPath}/statics/js/jquery-3.1.1.min.js"></script>
  <%--第二步写ajax请求--%>
  <script>
    function a1(){
     
      $.post({
     
        url:"${pageContext.request.contextPath}/a1",
        data:{
     'name':$("#txtName").val()},
        success:function (data,status) {
     
          alert(data);
          alert(status);
        }
      });
    }
  </script>
</head>
<body>
<%--第一步写一个输入框,绑定事件--%>
<%--onblur:失去焦点触发事件--%>
用户名:<input type="text" id="txtName" onblur="a1()" value="admin"/>

</body>
</html>

案例2:仿百度搜索栏

springMVC_Ajax小案例_第2张图片

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>JSONP百度搜索</title>
    <style>
        #q{
     
            width: 500px;
            height: 30px;
            border:1px solid #ddd;
            line-height: 30px;
            display: block;
            margin: 0 auto;
            padding: 0 10px;
            font-size: 14px;
        }
        #ul{
     
            width: 520px;
            list-style: none;
            margin: 0 auto;
            padding: 0;
            border:1px solid #ddd;
            margin-top: -1px;
            display: none;
        }
        #ul li{
     
            line-height: 30px;
            padding: 0 10px;
        }
        #ul li:hover{
     
            background-color: #f60;
            color: #fff;
        }
    </style>
    <script>

        // 2.步骤二
        // 定义demo函数 (分析接口、数据)
        function demo(data){
     
            var Ul = document.getElementById('ul');
            var html = '';
            // 如果搜索数据存在 把内容添加进去
            if (data.s.length) {
     
                // 隐藏掉的ul显示出来
                Ul.style.display = 'block';
                // 搜索到的数据循环追加到li里
                for(var i = 0;i<data.s.length;i++){
     
                    html += '
  • '+data.s[i]+'
  • '
    ; } // 循环的li写入ul Ul.innerHTML = html; } } // 1.步骤一 window.onload = function(){ // 获取输入框和ul var Q = document.getElementById('q'); var Ul = document.getElementById('ul'); // 事件鼠标抬起时候 Q.onkeyup = function(){ // 如果输入框不等于空 if (this.value != '') { // ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆JSONPz重点☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ // 创建标签 var script = document.createElement('script'); //给定要跨域的地址 赋值给src //这里是要请求的跨域的地址 我写的是百度搜索的跨域地址 script.src = 'https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd='+this.value+'&cb=demo'; // 将组合好的带src的script标签追加到body里 document.body.appendChild(script); } } } </script> </head> //输入框,设置id绑定事件 <body> <input type="text" id="q" /> <ul id="ul"> </ul> </body> </html>

    案例三:点击按钮获取LIst<>数据,进行数据填充

    springMVC_Ajax小案例_第3张图片

    第一步:编写controller接口

     @RequestMapping("/a2")
        public List<User> ajax2(){
         
            List<User> list = new ArrayList<User>();
            list.add(new User("1号",3,"男"));
            list.add(new User("2号",3,"男"));
            list.add(new User("3号",3,"男"));
            return list; //由于@RestController注解,将list转成json格式返回
        }
    

    第二步:编写前端界面

    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <html>
    <head>
        <title>Title</title>
    </head>
    <body>
    <input type="button" id="btn" value="获取数据"/>
    <table width="80%" align="center">
        <tr>
            <td>姓名</td>
            <td>年龄</td>
            <td>性别</td>
        </tr>
        <tbody id="content">
        </tbody>
    </table>
    
    <script src="${pageContext.request.contextPath}/statics/js/jquery-3.1.1.min.js"></script>
    <script>
        $(function () {
         
            $("#btn").click(function () {
         
                $.post("${pageContext.request.contextPath}/a2", function (data) {
         
                    console.log(data)
                    var html = "";
                    for (var i = 0; i < data.length; i++) {
         
                        html += "" +
                            "" + data[i].name + "" +
                            "" + data[i].age + "" +
                            "" + data[i].sex + "" +
                            ""
                    }
                    $("#content").html(html);
                });
            })
        })
    
    
    </script>
    </body>
    </html>
    

    案例四:表单信息验证

    springMVC_Ajax小案例_第4张图片
    第一步:编写controller接口

     @RequestMapping("/a3")
        public String ajax3(String name,String pwd){
         
            String msg="";
            if(name!=null){
         
                if("admin".equals(name)){
         
                    System.out.println("OK");
                    msg="OK";
    
                }else{
         
                    System.out.println("密码输入错误");
                    msg="用户名输入错误";
                }
            }
            if(pwd!=null){
         
                if ("123456".equals(pwd)){
         
                    System.out.println("OK");
                    msg="OK";
                }else{
         
                    System.out.println("密码输入错误");
                    msg="密码输入错误";
                }
    
            }
    
            return msg;
        }
    

    第二步:编写前端界面

    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <html>
    <head>
        <title>ajax</title>
        <script src="${pageContext.request.contextPath}/statics/js/jquery-3.1.1.min.js"></script>
        <script>
    
            function a1(){
         
                $.post({
         
                    url:"${pageContext.request.contextPath}/a3",
                    data:{
         'name':$("#name").val()},
                    success:function (data) {
         
                        if (data.toString()=='OK'){
         
                            $("#userInfo").css("color","green");
                        }else {
         
                            $("#userInfo").css("color","red");
                        }
                        $("#userInfo").html(data);
                    }
                });
            }
            function a2(){
         
                $.post({
         
                    url:"${pageContext.request.contextPath}/a3",
                    data:{
         'pwd':$("#pwd").val()},
                    success:function (data) {
         
                       // alert(data);
                        if (data.toString()=='OK'){
         
                            $("#pwdInfo").css("color","green");
                        }else {
         
                            $("#pwdInfo").css("color","red");
                        }
    
                        $("#pwdInfo").html(data);
                    }
                });
            }
    
        </script>
    </head>
    <body>
    <p>
        用户名:<input type="text" id="name" onblur="a1()"/>
        <span id="userInfo"></span>
    </p>
    <p>
        密码:<input type="text" id="pwd" onblur="a2()"/>
        <span id="pwdInfo"></span>
    </p>
    </body>
    </html>
    

    你可能感兴趣的:(ssm,ajax)