Ajax(基本介绍+使用+示例代码+场景回放)

一、基本介绍

AJAX(Asynchronous JavaScript and XML)是一种在无需重新加载整个页面的情况下,通过后台异步加载数据并更新页面的技术。虽然 AJAX 的名称中包含 “XML”,但实际上它通常使用 JSON 格式来传输数据。

AJAX 的核心是使用 XMLHttpRequest 对象(或在现代浏览器中使用 Fetch API)来与服务器进行异步通信。这允许在不刷新整个页面的情况下发送和接收数据,从而提高用户体验。

二、适用场景

AJAX(Asynchronous JavaScript and XML)适用于需要在无需重新加载整个页面的情况下,通过异步加载数据或与服务器进行通信的场景。以下是一些适用场景:

  1. 动态加载数据: 当页面需要动态加载数据,而无需刷新整个页面时,可以使用 AJAX。例如,在社交媒体网站上,动态加载新的帖子或评论,而无需刷新整个页面。

  2. 表单验证和提交: 在表单验证时,可以使用 AJAX 在后台验证用户输入,而无需提交整个表单。这允许用户在不离开当前页面的情况下得到实时反馈。如果验证通过,可以使用 AJAX 将表单数据提交到服务器。

  3. 实时搜索: 在搜索框中输入关键字时,可以使用 AJAX 向服务器发送异步请求,实时获取匹配的搜索结果,并将结果显示在页面上,而无需刷新整个页面。

  4. 聊天应用: 在在线聊天应用中,通过 AJAX 可以异步地发送和接收消息,从而实现实时聊天的效果。

  5. 更新部分页面内容: 如果只需要更新页面的一部分内容,而不是整个页面,例如在购物网站上更新购物车状态,可以使用 AJAX。

  6. 无需中断用户操作: AJAX 允许在后台进行数据交换,而不会中断用户对页面的操作。这提高了用户体验,使用户感觉页面更加流畅。

  7. 单页应用(SPA): 在单页应用中,页面的大部分内容由前端动态加载,而不是通过传统的页面刷新方式。 AJAX 在这种情况下是不可或缺的,用于获取和更新数据,以及处理用户交互。

AJAX 是一种强大的技术,可以提高用户体验,减少页面加载时间,并允许开发者在不刷新整个页面的情况下进行数据交互。然而,需要谨慎使用,确保数据安全性和用户友好性。

三、示例

以下是一个简单的使用 AJAX 的例子,演示如何通过 JavaScript 发送异步请求并处理服务器响应:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>AJAX 示例</title>
</head>
<body>

<button onclick="loadData()">加载数据</button>
<div id="result"></div>

<script>
function loadData() {
  // 创建 XMLHttpRequest 对象
  var xhr = new XMLHttpRequest();

  // 配置请求,指定请求方法和URL
  xhr.open("GET", "https://jsonplaceholder.typicode.com/posts/1", true);

  // 定义请求完成后的回调函数
  xhr.onreadystatechange = function() {
    // 请求完成且响应状态为 200 表示成功
    if (xhr.readyState == 4 && xhr.status == 200) {
      // 解析服务器响应的 JSON 数据
      var data = JSON.parse(xhr.responseText);

      // 更新页面上的内容
      document.getElementById("result").innerHTML = "Title: " + data.title;
    }
  };

  // 发送请求
  xhr.send();
}
</script>

</body>
</html>

在这个例子中,点击按钮会触发 loadData 函数,该函数使用 XMLHttpRequest 对象发送 GET 请求到指定的 URL(这里使用了一个示例的 JSONPlaceholder API)。在请求完成后,通过回调函数处理服务器的响应,更新页面上的内容。

需要注意的是,现代的前端开发通常使用 Fetch API 替代 XMLHttpRequest,因为它提供了更简单、更强大的方式来处理异步请求。以下是一个使用 Fetch API 的示例:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>AJAX 示例</title>
</head>
<body>

<button onclick="loadData()">加载数据</button>
<div id="result"></div>

<script>
function loadData() {
  // 使用 Fetch API 发送异步请求
  fetch("https://jsonplaceholder.typicode.com/posts/1")
    .then(response => response.json())
    .then(data => {
      // 更新页面上的内容
      document.getElementById("result").innerHTML = "Title: " + data.title;
    })
    .catch(error => console.error('Error:', error));
}
</script>

</body>
</html>

这个示例使用了 Fetch API,通过 fetch 函数发送异步请求,并使用 then 处理服务器的响应。 Fetch API 更简洁、易读,并支持 Promise。

当涉及 AJAX 时,有许多不同的使用情景和示例。以下是更多的 AJAX 示例,涵盖了一些常见的应用场景:

1. 实时天气预报:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>AJAX 示例 - 实时天气预报</title>
</head>
<body>

<input type="text" id="cityInput" placeholder="输入城市">
<button onclick="getWeather()">获取天气</button>
<div id="weatherResult"></div>

<script>
function getWeather() {
  var city = document.getElementById("cityInput").value;

  // 使用 AJAX 获取实时天气数据
  var xhr = new XMLHttpRequest();
  xhr.open("GET", "https://api.openweathermap.org/data/2.5/weather?q=" + city + "&appid=YOUR_API_KEY", true);

  xhr.onreadystatechange = function() {
    if (xhr.readyState == 4 && xhr.status == 200) {
      var weatherData = JSON.parse(xhr.responseText);
      document.getElementById("weatherResult").innerHTML = "当前天气:" + weatherData.weather[0].description;
    }
  };

  xhr.send();
}
</script>

</body>
</html>

2. 实时股票价格:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>AJAX 示例 - 实时股票价格</title>
</head>
<body>

<input type="text" id="stockSymbolInput" placeholder="输入股票代码">
<button onclick="getStockPrice()">获取股票价格</button>
<div id="stockPriceResult"></div>

<script>
function getStockPrice() {
  var stockSymbol = document.getElementById("stockSymbolInput").value;

  // 使用 AJAX 获取实时股票价格
  var xhr = new XMLHttpRequest();
  xhr.open("GET", "https://api.example.com/stock-price?symbol=" + stockSymbol, true);

  xhr.onreadystatechange = function() {
    if (xhr.readyState == 4 && xhr.status == 200) {
      var stockPriceData = JSON.parse(xhr.responseText);
      document.getElementById("stockPriceResult").innerHTML = "当前股价:" + stockPriceData.price;
    }
  };

  xhr.send();
}
</script>

</body>
</html>

3. 异步加载文章评论:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>AJAX 示例 - 异步加载文章评论</title>
</head>
<body>

<button onclick="loadComments()">加载评论</button>
<ul id="commentList"></ul>

<script>
function loadComments() {
  // 使用 AJAX 异步加载文章评论
  var xhr = new XMLHttpRequest();
  xhr.open("GET", "https://api.example.com/comments?articleId=123", true);

  xhr.onreadystatechange = function() {
    if (xhr.readyState == 4 && xhr.status == 200) {
      var commentsData = JSON.parse(xhr.responseText);
      var commentList = document.getElementById("commentList");

      // 清空现有评论列表
      commentList.innerHTML = "";

      // 添加新的评论
      commentsData.forEach(function(comment) {
        var li = document.createElement("li");
        li.textContent = comment.text;
        commentList.appendChild(li);
      });
    }
  };

  xhr.send();
}
</script>

</body>
</html>

这些示例展示了如何使用 AJAX 处理不同的场景,包括获取实时天气预报、实时股票价格和异步加载文章评论。

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是基于SSM+Shiro+Ajax+MD5的登录的详细代码: 1. 前端页面代码 login.jsp ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>登录</title> <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script> </head> <body> <h1>登录</h1> <form id="loginForm"> <div> <label>用户名:</label> <input type="text" name="username" required> </div> <div> <label>密码:</label> <input type="password" name="password" required> </div> <div> <label>验证码:</label> <input type="text" name="captcha" required> <img id="captchaImg" src="/captcha.jpg" alt="验证码" onclick="this.src='/captcha.jpg?'+Math.random()"> </div> <div> <input type="submit" value="登录"> </div> </form> <script> $(function() { $('#loginForm').submit(function(event) { event.preventDefault(); var formData = $(this).serialize(); $.ajax({ url: '/login', type: 'POST', data: formData, dataType: 'json', success: function(result) { if (result.success) { window.location.href = '/home'; } else { alert(result.message); $('#captchaImg').click(); } }, error: function() { alert('服务器错误,请稍后再试!'); } }); }); }); </script> </body> </html> ``` 2. 后端代码 UserController.java ```java @Controller public class UserController { @Autowired private UserService userService; @RequestMapping("/login") @ResponseBody public Result login(@RequestParam("username") String username, @RequestParam("password") String password, @RequestParam("captcha") String captcha, HttpSession session) { // 验证码校验 String realCaptcha = (String) session.getAttribute("captcha"); if (!captcha.equalsIgnoreCase(realCaptcha)) { return new Result("验证码错误!", false); } // 用户名密码校验 User user = userService.findByUsername(username); if (user == null) { return new Result("用户不存在!", false); } String md5Password = MD5Util.md5(password, user.getSalt()); if (!md5Password.equals(user.getPassword())) { return new Result("密码错误!", false); } // 登录成功,将用户信息保存到Session中 session.setAttribute("user", user); return new Result("登录成功!", true); } } ``` UserService.java ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public User findByUsername(String username) { return userMapper.findByUsername(username); } } ``` UserMapper.xml ```xml <mapper namespace="com.example.mapper.UserMapper"> <select id="findByUsername" parameterType="java.lang.String" resultType="com.example.entity.User"> select * from user where username=#{username} </select> </mapper> ``` UserMapper.java ```java public interface UserMapper { User findByUsername(String username); } ``` MD5Util.java ```java public class MD5Util { public static String md5(String str, String salt) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest((str + salt).getBytes("utf-8")); StringBuilder sb = new StringBuilder(); for (byte b : bytes) { String hex = Integer.toHexString(b & 0xff); if (hex.length() == 1) { sb.append("0"); } sb.append(hex); } return sb.toString(); } catch (Exception e) { throw new RuntimeException(e); } } } ``` ShiroConfig.java ```java @Configuration public class ShiroConfig { @Autowired private UserService userService; @Bean public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); shiroFilterFactoryBean.setSecurityManager(securityManager); shiroFilterFactoryBean.setLoginUrl("/login"); shiroFilterFactoryBean.setUnauthorizedUrl("/403"); Map<String, String> filterChainDefinitionMap = new LinkedHashMap<>(); filterChainDefinitionMap.put("/login", "anon"); filterChainDefinitionMap.put("/logout", "logout"); filterChainDefinitionMap.put("/**", "authc"); shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap); return shiroFilterFactoryBean; } @Bean public SecurityManager securityManager() { DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(); securityManager.setRealm(realm()); return securityManager; } @Bean public UserRealm realm() { UserRealm realm = new UserRealm(); realm.setCredentialsMatcher(credentialsMatcher()); return realm; } @Bean public HashedCredentialsMatcher credentialsMatcher() { HashedCredentialsMatcher credentialsMatcher = new HashedCredentialsMatcher(); credentialsMatcher.setHashAlgorithmName("MD5"); credentialsMatcher.setHashIterations(1); return credentialsMatcher; } public class UserRealm extends AuthorizingRealm { @Override protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) { SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo(); return authorizationInfo; } @Override protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException { UsernamePasswordToken upToken = (UsernamePasswordToken) token; String username = upToken.getUsername(); User user = userService.findByUsername(username); if (user == null) { throw new UnknownAccountException("用户不存在!"); } SimpleAuthenticationInfo authenticationInfo = new SimpleAuthenticationInfo(user.getUsername(), user.getPassword(), ByteSource.Util.bytes(user.getSalt()), getName()); return authenticationInfo; } } } ``` 3. 实体类代码 User.java ```java public class User implements Serializable { private Long id; private String username; private String password; private String salt; // getter/setter方法省略 } ``` 4. 配置文件代码 application.properties ```properties server.port=8080 spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver mybatis.mapper-locations=classpath:mapper/*.xml mybatis.type-aliases-package=com.example.entity shiro.loginUrl=/login ``` 以上是基于SSM+Shiro+Ajax+MD5的登录的详细代码,其中包括了前端页面代码、后端代码、实体类代码和配置文件代码。该代码实现了基本的登录功能,包括了用户名密码校验、验证码校验、MD5加密等功能。可以根据需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值