AJAX简介

AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。

AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。

AJAX 不是新的编程语言,而是一种使用现有标准的新方法。

AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。

AJAX 不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。

 

AJAX 应用

  • 运用XHTML+CSS来表达资讯;

  • 运用JavaScript操作DOM(Document Object Model)来执行动态效果;

  • 运用XML和XSLT操作资料;

  • 运用XMLHttpRequest或新的Fetch API与网页服务器进行异步资料交换;

  • 注意:AJAX与Flash、Silverlight和Java Applet等RIA技术是有区分的。

AJAX是基于现有的Internet标准

  • XMLHttpRequest 对象 (异步的与服务器交换数据)
  • JavaScript/DOM (信息显示/交互)
  • CSS (给数据定义样式)
  • XML (作为转换数据的格式)

举例:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
  <body>
    <h2>问题1:</h2>
    <div id="q1"></div>
    <div id="a1"></div>
    
    <button onclick="loadQuestion()">加载问题</button>
    <button onclick="loadAnswer()">查看答案</button>
  </body>
  
  <script>
  	function loadQuestion(){
  		var xhr = new XMLHttpRequest();     //XMLHttpRequest用于发送和接收http请求
  		
  		xhr.onreadystatechange = function(){     //响应完成后触发
  			if(xhr.readyState == 4 && xhr.status == 200){  //readyState == 4表示响应已完成
  				document.getElementById("q1").innerHTML = xhr.responseText;  //把响应的内容放到q1里面
  			}
  		};
  		
  		xhr.open("GET", "file/question.txt", true);   //true表示异步调用, false同步调用
  		xhr.send();
  		
  		/* if(xhr.readyState == 4 && xhr.status == 200){  
			document.getElementById("q1").innerHTML = xhr.responseText; 
		} */
  	}
  	
  	
  	function loadAnswer(){
  		var xhr = new XMLHttpRequest();     //XMLHttpRequest用于发送和接收http请求
  		
  		xhr.onreadystatechange = function(){     //响应完成后触发
  			if(xhr.readyState == 4 && xhr.status == 200){  //readyState == 4表示响应已完成
  				document.getElementById("a1").innerHTML = xhr.responseText;  //把响应的内容放到q1里面
  			}
  		};
  		
  		xhr.open("GET", "file/answer.txt", true);   //true表示异步调用, false同步调用
  		xhr.send();
  		
  	}
  
  
  </script>
</html>

 

 

出现这个错误的原因是在导入seaborn包时,无法从typing模块中导入名为'Protocol'的对象。 解决这个问题的方法有以下几种: 1. 检查你的Python版本是否符合seaborn包的要求,如果不符合,尝试更新Python版本。 2. 检查你的环境中是否安装了typing_extensions包,如果没有安装,可以使用以下命令安装:pip install typing_extensions。 3. 如果你使用的是Python 3.8版本以下的版本,你可以尝试使用typing_extensions包来代替typing模块来解决该问题。 4. 检查你的代码是否正确导入了seaborn包,并且没有其他导入错误。 5. 如果以上方法都无法解决问题,可以尝试在你的代码中使用其他的可替代包或者更新seaborn包的版本来解决该问题。 总结: 出现ImportError: cannot import name 'Protocol' from 'typing'错误的原因可能是由于Python版本不兼容、缺少typing_extensions包或者导入错误等原因造成的。可以根据具体情况尝试上述方法来解决该问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [ImportError: cannot import name ‘Literal‘ from ‘typing‘ (D:\Anaconda\envs\tensorflow\lib\typing....](https://blog.youkuaiyun.com/yuhaix/article/details/124528628)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值